您当前的位置:首页 > 网站建设 > javascript
| php | asp | css | H5 | javascript | Mysql | Dreamweaver | Delphi | 网站维护 | 帝国cms | React | 考试系统 | ajax |

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

51自学网 2022-05-02 21:35:02
  javascript

逻辑分层

我们在使用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 逻辑抽离和字段显示内容请搜索wanshiok.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持wanshiok.com!


Bootstrap+Jquery实现日历效果
js和jquery实现tab状态栏切换效果
51自学网,即我要自学网,自学EXCEL、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。
京ICP备13026421号-1