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

目录
  • 逻辑分层
  • 将各个区域业务分开
  • 这样做的优势
  • 这样的场景应该如何处理
  • 优化
  • reactive 不一定非要写在setup函数中
  • 如何在页面上直接显示值

逻辑分层

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

(0)

相关推荐

  • Vue实现用户自定义字段显示数据的方法

    如下: 代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible&q

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

    目录 逻辑分层 将各个区域业务分开 这样做的优势 这样的场景应该如何处理 优化 reactive 不一定非要写在setup函数中 如何在页面上直接显示值 逻辑分层 我们在使用vue3开发项目的时候, 如何进行[区域分层]呢???? 举一个简单的小粒子 一个区域有[查询逻辑.修改后的保存逻辑.新增逻辑.删除逻辑] 这个页面可能还有其他的区域.A区域.B区域,C区域...[有很多逻辑] 这个时候我们可以将一个区域的逻辑分离出去 将各个区域业务分开 export default { setup ()

  • 浅谈在JAVA项目中LOG4J的使用

    一.直接使用: //输出到项目文件夹下output1.txt文件中 ////////////////////////////// // DEBUG - Here is some DEBUG // INFO - Here is some INFO // WARN - Here is some WARN // ERROR - Here is some ERROR // FATAL - Here is some FATAL ////////////////////////////// package

  • 浅谈如何在项目中使用Spring Cloud Alibaba Sentinel组件

    目录 Sentinel 是什么 Sentinel与Hystrix的区别 Sentinel分为两大部分: 一.控制台(Dashboard) 二.搭建客户端 1.在自己的项目中引入依赖 2.编辑项目中的 application.yml或者bootstrap.yml文件 3.资源是 Sentinel 中的一个关键概念.它可以是任何东西,例如服务.方法,甚至是代码片段. 三.查看接口的流量的详情 1.实时监控 2.簇点链路 3.等等:其他使用方法有待发掘 Sentinel 是什么 随着微服务的流行,服务

  • 浅谈redis在项目中的应用

    redis在项目中的应用 ps:PHP 会自动 关redis连接 不需要手动关 对于临时的数据 可以不经过数据库直接redis上操作 /*消息队列实例 */ public function insertinfo(){ //连接本地的 Redis 服务 $redis = new \Redis(); $redis->connect('127.0.0.1', 6379); //存储数据到列表中 $infos = array('info1' => 66, 'info2' => 88); $red

  • 浅谈web服务器项目中request请求和response的相关响应处理

    我们经常使用别人的服务器进行构建网站,现在我们就自己来写一个自己的服务来使用. 准备工作:下载所需的题材及文档 注:完整项目下载 一.request请求获取  1.了解request请求 在写服务器之前,我们需要知道客户端发送给我们哪些信息?以及要求我们返回哪些信息?经过测试我们能够知道用户客户端发送的信息有以下几点: 客户端发送到服务器端的请求消息,我们称之为请求(request),其实就是一个按照http协议的规则拼接而成的字符串,Request请求消息包含三部分: 请求行 消息报头 请求正

  • 浅谈web服务器项目中静态请求和动态请求处理

    注:完整项目下载 在处理了核心任务之后,我们会发现有些请求并不是都是静态的,那么我们就需要进行实现处理动态请求的要求,如下面代码是我们请求的解决方式,我们只需在HttpRequestImpl实现类中,将如下代码实现具体的判断过程 //判断当前请求的否是静态资源 public boolean isStaticResource(){ return true; } //判断当前请求的否是动态资源 public boolean isDynamicResource(){ return true; } 1.

  • 浅谈在vue-cli3项目中解决动态引入图片img404的问题

    博主最近手头再做一个项目,需要调用天气接口,并且还要动态显示天气相关图片icon. 本来以为没什么大问题,结果硬生生被这个动态图片路径搞得民不聊生(博主还是 too young,too simple~),给出效果图: 就是那个红框选中的那个天气状况图标icon要根据当前城市获取当前城市天气状态码,再根据当前城市状态码找到这个对应的天气图标icon~~ 按照一般的开发模式,静态图片路径是相对路径还是绝对路径都可以,因为图片路径是静态的是死的,所以webpack去找这个图片路径的时候是能找到的. 但

  • 浅谈JAVA在项目中如何自定义异常

    JAVA项目中自定义异常 1.数据返回处理类 @Data public class R<T> implements Serializable { private static final long serialVersionUID = -8497670085742879369L; @ApiModelProperty(value = "返回码", example = "200") private Integer code=200; @ApiModelPro

  • 浅谈在vue项目中如何定义全局变量和全局函数

    写在前面: 如题,在项目中,经常有些函数和变量是需要复用,比如说网站服务器地址,从后台拿到的:用户的登录token,用户的地址信息等,这时候就需要设置一波全局变量和全局函数,这两个设置不太难,而且有一些共通之处,可能有一些朋友对此不太了解,所以随便写出来分享一波.有需要的朋友可以做一下参考,喜欢的可以点波赞,或者关注一下,希望可以帮到大家. 定义全局变量 原理: 设置一个专用的的全局变量模块文件,模块里面定义一些变量初始状态,用export default 暴露出去,在main.js里面使用Vu

  • 浅谈Vue3中watchEffect的具体用法

    前言 watchEffect,它立即执行传入的一个函数,同时响应式追踪其依赖,并在其依赖变更时重新运行该函数. 换句话说:watchEffect相当于将watch 的依赖源和回调函数合并,当任何你有用到的响应式依赖更新时,该回调函数便会重新执行.不同于 watch,watchEffect 的回调函数会被立即执行(即 { immediate: true }) 此文主要讲述怎样利用清除副作用使我们的代码更加优雅~ watchEffect的副作用 什么是副作用(side effect),简单的说副作用

随机推荐