浅谈vue3在项目中的逻辑抽离和字段显示

 更新时间:2021年08月10日 09:22:51   作者:我的div丢了肿么办  
本文主要介绍了vue3在项目中的逻辑抽离和字段显示,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

逻辑分层

我们在使用vue3开发项目的时候,
如何进行【区域分层】呢????
举一个简单的小粒子
一个区域有【查询逻辑、修改后的保存逻辑、新增逻辑、删除逻辑】
这个页面可能还有其他的区域。A区域、B区域,C区域...【有很多逻辑】
这个时候我们可以将一个区域的逻辑分离出去

将各个区域业务分开

export default {
  setup () {
    let {queryDo,addDo,delDO,EditDo}=allFun();
    queryDo();//查询接口就会被调用了
  
  }
}

// 这个是页面A区域的逻辑
function allFun(){
  console.log('我是 allFun 函数内的直接语句我将会被执行' )
  function queryDo(){
    console.log('我是查询接口,调用后端的数据')
  }
  function addDo(){
    console.log('我是新增')
  }
  function delDO(){
    console.log('我是删除')
  }
  function EditDo(){
    console.log('我是编辑接口')
  }
  return {queryDo,addDo,delDO,EditDo}
}
</script>

这样做的优势

  • 当我们看见 allFun函数的时候。
  • 我们就可以知道这个区域的所有逻辑
  • 包含crud。方便后期的维护

这样的场景应该如何处理

在我们写业务逻辑的时候,
我们最后发现 A和B两个区域都需要调用同一个接口
但是由于A区域已经写好了这个被调用的接口
这个时候我就想直接去调用A区域中的接口

<script>
export default {
  setup () {
    // 这里使用的是结构,A区域
    let {queryDo,addDo,delDO,EditDo}=aAreaAllFun();

    // B区域
    let {querHander}=bAreaAllFun();

    return {queryDo,addDo,delDO,EditDo,querHander}
  }
}

// 这个是A区域页面某个区域的逻辑
function aAreaAllFun(){
  function queryDo(){
    console.log('我是A区域的查询接口')
  }
  function addDo(){
    console.log('我是新增')
  }
  function delDO(){
    console.log('我是删除')
  }
  function EditDo(){
    console.log('我是编辑接口')
  }
  return {queryDo,addDo,delDO,EditDo}
}

// 这是B区域的业务逻辑
function bAreaAllFun(){
  // 直接去调用A区域的查询接口
  aAreaAllFun().queryDo();

  function querHander(){
    console.log("B区域的查询接口")
  }
 
  return {querHander}
}
</script>

虽然使用
aAreaAllFun().queryDo();
直接去调用A区域的查询接口
解决了问题
但是这样产生了一个新的问题是
查询接口被包含在了A区域;
最后的做法是查询接口应该单独抽离出去,
这样也方便后期我们的维护

优化

<script>
export default {
  setup () {
     // 这个是A区域页面某个区域的逻辑
    let {addDo,delDO,EditDo}=aAreaAllFun()
    
    // 这个是B区域页面某个区域的逻辑
    let {querHander}=bAreaAllFun();

    return {queryDo,addDo,delDO,EditDo,querHander}
  }
}

// 公共的查询接口 很多区域可能会使用
function queryDo(){
  console.log('我是区域的查询接口,我被抽离出去了')
}

// 这个是A区域页面某个区域的逻辑
function aAreaAllFun(){
 
  function addDo(){
    console.log('我是新增')
  }
  function delDO(){
    console.log('我是删除')
  }
  function EditDo(){
    console.log('我是编辑接口')
  }
  return {addDo,delDO,EditDo}
}

// 这是B区域的业务逻辑
function bAreaAllFun(){
  // 直接去调用公共的查询接口
   queryDo();

  function querHander(){
    console.log("B区域的查询接口")
  }
 
  return {querHander}
}
</script>

reactive 不一定非要写在setup函数中

很多的小伙伴以为reactive一定要写在setup函数中
其实不是这样的哈
它可以写在你需要的地方
比如下面的aAreaAllFun函数中可以使用reactive

<template>
  <div>
    <h2>姓名: {{ areaData.info.name}}</h2>
    <h2>年龄: {{ areaData.info.age}}</h2>
    <h2>性别: {{ areaData.info.sex}}</h2>
  </div>
</template>
<script>
import { reactive } from '@vue/reactivity';
export default {
  setup () {
 
    let {addDo,areaData}=aAreaAllFun();

    return {addDo,areaData}
  }
}
// 这个是A区域页面某个区域的逻辑
function aAreaAllFun(){
  let areaData=reactive({
    info:{
      name:'张三',
      age:20,
      sex:'男'
    }
  })
  function addDo(){
    console.log('我是新增')
  }
  return {addDo,areaData}
}
</script>

如何在页面上直接显示值

在上面这个例子中
我们想要实现姓名、年龄、和性别
我们需要 areaData.info.xxx
这样做太麻烦了,我们需要优化一下

<template>
  <div>
    <h2>姓名: {{ name}}</h2>
    <h2>年龄: {{ age}}</h2>
    <h2>性别: {{ sex}}</h2>
  </div>

  <button @click="ChangeCont">改变值</button>
</template>
<script>
import { reactive,toRefs } from 'vue';
export default {
  setup () {
    let {name,age,sex,ChangeCont }=aAreaAllFun();
    return {name,age,sex,ChangeCont}
  }
}
// 这个是A区域页面某个区域的逻辑
function aAreaAllFun(){
  let areaData=reactive({
    info:{
      name:'张三',
      age:20,
      sex:'男'
    }
  })

  function ChangeCont(){
    // 这样更改值,视图上是不会响应的哈【错误的】
    // areaData.info={
    //   name:'李四',
    //   age:21,
    //   sex:'男'
    // }

    // 这样是可以的正确跟新视图的 【ok的】
    areaData.info.name='123'
    areaData.info.age=12
    areaData.info.sex='男'
  }

  //   toRefs 可以把一个响应式对象转换为普通的对象。
  // 该普通对象的每一个值都是ref。
  // 由于变成了ref,所以我们需要使用value。
  return {ChangeCont,...toRefs(areaData.info)}
}
</script>

到此这篇关于浅谈vue3在项目中的逻辑抽离和字段显示的文章就介绍到这了,更多相关vue3 逻辑抽离和字段显示内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vite多环境配置及变量识别规则

    Vite多环境配置及变量识别规则

    这篇文章主要为大家介绍了Vite多环境配置时间及vite识别环境变量的规则,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09
  • 解决Vue.js应用回退或刷新界面时提示用户保存修改问题

    解决Vue.js应用回退或刷新界面时提示用户保存修改问题

    这篇文章主要介绍了Vue.js应用回退或刷新界面时提示用户保存修改问题,本文通过两种手段防止运营编辑时丢失数据,具体内容详情,感兴趣的朋友跟随小编一起看看吧
    2019-11-11
  • 解决ele ui 表格表头太长问题的实现

    解决ele ui 表格表头太长问题的实现

    这篇文章主要介绍了解决ele ui 表格表头太长问题的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-11-11
  • vue中的slot封装组件弹窗

    vue中的slot封装组件弹窗

    这篇文章主要介绍了vue中的slot封装组件弹窗,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-05-05
  • webpack项目中使用vite加速的兼容模式详解

    webpack项目中使用vite加速的兼容模式详解

    这篇文章主要为大家介绍了webpack项目中使用vite加速的兼容模式示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • vue使用this.$message不生效的部分原因及解决方案

    vue使用this.$message不生效的部分原因及解决方案

    这篇文章主要介绍了vue使用this.$message不生效的部分原因及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • Vue中如何设置全局的cookie对象

    Vue中如何设置全局的cookie对象

    这篇文章主要介绍了Vue中如何设置全局的cookie对象,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • vue项目ElementUI组件中el-upload组件与图片裁剪功能组件结合使用详解

    vue项目ElementUI组件中el-upload组件与图片裁剪功能组件结合使用详解

    这篇文章主要介绍了vue项目ElementUI组件中el-upload组件与图片裁剪功能组件结合使用,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • 轻松学Vue组件之单文件组件

    轻松学Vue组件之单文件组件

    一个组件相当于是一个小模块,它是html、css与js的集合体,可以用于描述页面中的某个结构(模块),下面这篇文章主要给大家介绍了关于轻松学Vue组件之单文件组件的相关资料,需要的朋友可以参考下
    2023-03-03
  • 在Vue的mounted中仍然加载渲染不出echarts的方法问题

    在Vue的mounted中仍然加载渲染不出echarts的方法问题

    这篇文章主要介绍了在Vue的mounted中仍然加载渲染不出echarts的方法问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03

最新评论