【Vue3从零开始-实战】S11:setup函数的职责及封装setup函数中的逻辑

简介: 【Vue3从零开始-实战】S11:setup函数的职责及封装setup函数中的逻辑

@@DVBVTGC2D7ROIYF4YK_@O.png


前言


实战已经开始了!上一篇文章中我们把Toast组件拆分出来了,并且把其中的逻辑部分也从Login组件中的setup函数中拆分到其组件中去。


其实一个setup函数主要是做什么呢?它的职责又是干啥呢?和vue2中的methods方法有什么区别呢?


在setup函数中,可以用物以类聚人以群分来形容我们的代码逻辑,也就是关于某一块的东西可以放在一起去管理。然而我们在Login.vue页面里面写的代码还不算完全物以类聚了,有些地方还是比较分散的。所以下面我们就需要去把setup函数中的逻辑都分门别类的拆分出来。


拆分Login逻辑


👉 在拆分之前,我们要明确一点,哪些属于Login的逻辑模块。


👉 我们在Login组件页面会发现,有两个input输入框需要进行双向数据绑定,还需要请求mock接口进行登录,最后将错误提示通过Toast组件显示出来。


👉 按照这个逻辑,我们就先将数据绑定的提取出来。


👉 为了更好的绑定数据,我们需要使用以前学过的toRefs方法去解构data里面的值,所以要先引用toRefs


import { reactive, toRefs } from 'vue'
复制代码


👉 拆分Login逻辑部分还需要将它剥离出setup函数,所以需要在js中新建一个函数来封装Login的逻辑部分。


const useLoginEffect = (showToast) => {
    const router = useRouter()
    const data = reactive({ mobile: '', password: '' })
    const handleLogin = async () => {
        try {
            const result = await post('/api/user/login', {
                username: data.username,
                password: data.password
            })
            if (result.data.code === 0) {
                localStorage.isLogin = true
                router.push({ name: 'Home' })
            } else {
                showToast('登陆失败')
            }
        } catch (e) {
            showToast('请求失败')
        }
    }
    const { mobile, password } = toRefs(data)
    return { handleLogin, mobile, password }
}
复制代码


  • useLoginEffect函数接收外部传递过来的showToast方法。


  • 将数据值return出去之前,需要将输入框绑定的值从data中解构出来,这样在页面中就可以直接使用解构出来的值了,不需要通过data.xxx的方式来绑定了。


<div class="wrapper__input">
  <input class="wrapper__input__content" placeholder="请输入手机号" v-model="mobile" />
</div>
<div class="wrapper__input">
  <input class="wrapper__input__content" placeholder="请输入密码" v-model="password" />
</div>
复制代码


👉 拆分跳转注册的逻辑


// 处理注册跳转
const useRegisterEffect = () => {
  const router = useRouter()
  const handleRegisterClick = () => {
    router.push({ name: 'Register' })
  }
  return { handleRegisterClick }
}
复制代码


👉 在setup函数中就可以像获取Toast组件中的数据一样获取封装的Login逻辑了。


setup () {
    const router = useRouter()
    const { toastData, showToast } = useToastEffect()
    const { mobile, password, handleLogin } = useLoginEffect(showToast)
    const handleRegisterClick = () => {
      router.push({ name: 'Register' })
    }
    return { handleLogin, handleRegisterClick, mobile, password, toastData }
}
复制代码


  • 通过解构useLoginEffect方法,得到的数据值在通过setup函数return到外部使用。


🔆 这样拆分之后,setup函数里面的代码就会一目了然,需要修改某个部分的逻辑就直接找到对应的函数即可。不需要再像之前一样,数据和逻辑可能中间还插入了其他代码。


😲 登录页面中的逻辑都拆分完成了,我们也可以把注册的逻辑像登录一样去完善,并且调用mock接口。


注册逻辑


👉 在fastmock上新建注册接口


%G92)3OTK}TXJ5NWO4PWZM9.png


👉 注册组件中引入所需的模块


import { useRouter } from 'vue-router'
import { reactive, toRefs } from 'vue'
import { post } from '../../utils/request'
import Toast, { useToastEffect } from '../../components/Toast'
复制代码


👉 注册逻辑就不写在setup中了,直接就拆分成一个单独的方法


// 处理注册相关逻辑
const useRegisterEffect = (showToast) => {
  const router = useRouter()
  const data = reactive({
    mobile: '',
    password: '',
    ensurement: ''
  })
  const handleRegister = async () => {
    try {
      const result = await post('/api/user/register', {
        mobile: data.mobile,
        password: data.password
      })
      if (result.data.code === 0) {
        router.push({ name: 'Login' })
      } else {
        showToast('注册失败')
      }
    } catch (e) {
      showToast('请求失败')
    }
  }
  const { mobile, password, ensurement } = toRefs(data)
  return { mobile, password, ensurement, handleRegister }
}
复制代码


  • 注册逻辑和登录差不多,只是多了一个参数而已,接口名是新建的注册接口。


👉 将注册逻辑中的数据绑定到input输入框中


<div class="wrapper__input">
  <input class="wrapper__input__content" placeholder="请输入手机号" v-model="mobile" />
</div>
<div class="wrapper__input">
  <input class="wrapper__input__content" placeholder="请输入密码" type="password" v-model="password" />
</div>
<div class="wrapper__input">
  <input class="wrapper__input__content" placeholder="确认密码" type="password" v-model="ensurement" />
</div>
复制代码


👉 注册页还有一个跳转登录逻辑,也可以拆分出来


// 处理登陆跳转
const useLoginEffect = () => {
  const router = useRouter()
  const handleLoginClick = () => {
    router.push({ name: 'Login' })
  }
  return { handleLoginClick }
}
复制代码


👉 setup函数调用封装的逻辑方法


setup () {
    const { toastData, showToast } = useToastEffect()
    const { mobile, password, ensurement, handleRegister } = useRegisterEffect(showToast)
    const { handleLoginClick } = useLoginEffect()
    return {
      mobile,
      password,
      ensurement,
      toastData,
      handleRegister,
      handleLoginClick
    }
}
复制代码


V[]S}[AL7$F31WRRH47M8U9.png


总结


本篇文章主要讲解了setup函数的职责,就是为了方便我们知道代码执行的一个流程而已,没有过多的逻辑代码。所有的逻辑代码都可以封装在setup函数外部,然后进行引用或者调用之后再return给其他逻辑部分使用或者页面使用。

相关文章
|
28天前
|
缓存 JavaScript UED
Vue3中v-model在处理自定义组件双向数据绑定时有哪些注意事项?
在使用`v-model`处理自定义组件双向数据绑定时,要仔细考虑各种因素,确保数据的准确传递和更新,同时提供良好的用户体验和代码可维护性。通过合理的设计和注意事项的遵循,能够更好地发挥`v-model`的优势,实现高效的双向数据绑定效果。
128 64
|
28天前
|
JavaScript 前端开发 API
Vue 3 中 v-model 与 Vue 2 中 v-model 的区别是什么?
总的来说,Vue 3 中的 `v-model` 在灵活性、与组合式 API 的结合、对自定义组件的支持等方面都有了明显的提升和改进,使其更适应现代前端开发的需求和趋势。但需要注意的是,在迁移过程中可能需要对一些代码进行调整和适配。
108 60
|
2天前
|
JavaScript API 数据处理
vue3使用pinia中的actions,需要调用接口的话
通过上述步骤,您可以在Vue 3中使用Pinia和actions来管理状态并调用API接口。Pinia的简洁设计使得状态管理和异步操作更加直观和易于维护。无论是安装配置、创建Store还是在组件中使用Store,都能轻松实现高效的状态管理和数据处理。
16 3
|
28天前
|
前端开发 JavaScript 测试技术
Vue3中v-model在处理自定义组件双向数据绑定时,如何避免循环引用?
Web 组件化是一种有效的开发方法,可以提高项目的质量、效率和可维护性。在实际项目中,要结合项目的具体情况,合理应用 Web 组件化的理念和技术,实现项目的成功实施和交付。通过不断地探索和实践,将 Web 组件化的优势充分发挥出来,为前端开发领域的发展做出贡献。
32 8
|
27天前
|
存储 JavaScript 数据管理
除了provide/inject,Vue3中还有哪些方式可以避免v-model的循环引用?
需要注意的是,在实际开发中,应根据具体的项目需求和组件结构来选择合适的方式来避免`v-model`的循环引用。同时,要综合考虑代码的可读性、可维护性和性能等因素,以确保系统的稳定和高效运行。
30 1
|
27天前
|
JavaScript
Vue3中使用provide/inject来避免v-model的循环引用
`provide`和`inject`是 Vue 3 中非常有用的特性,在处理一些复杂的组件间通信问题时,可以提供一种灵活的解决方案。通过合理使用它们,可以帮助我们更好地避免`v-model`的循环引用问题,提高代码的质量和可维护性。
36 1
|
28天前
|
JavaScript
在 Vue 3 中,如何使用 v-model 来处理自定义组件的双向数据绑定?
需要注意的是,在实际开发中,根据具体的业务需求和组件设计,可能需要对上述步骤进行适当的调整和优化,以确保双向数据绑定的正确性和稳定性。同时,深入理解 Vue 3 的响应式机制和组件通信原理,将有助于更好地运用 `v-model` 实现自定义组件的双向数据绑定。
|
JavaScript
vue实战中的一些技巧《一》
vue实战中的一些技巧《一》
815 0
vue实战中的一些技巧《一》
|
1月前
|
JavaScript API 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
7天前
|
JavaScript 关系型数据库 MySQL
基于VUE的校园二手交易平台系统设计与实现毕业设计论文模板
基于Vue的校园二手交易平台是一款专为校园用户设计的在线交易系统,提供简洁高效、安全可靠的二手商品买卖环境。平台利用Vue框架的响应式数据绑定和组件化特性,实现用户友好的界面,方便商品浏览、发布与管理。该系统采用Node.js、MySQL及B/S架构,确保稳定性和多功能模块设计,涵盖管理员和用户功能模块,促进物品循环使用,降低开销,提升环保意识,助力绿色校园文化建设。