欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談vue3在項(xiàng)目中的邏輯抽離和字段顯示

 更新時(shí)間:2021年08月10日 09:22:51   作者:我的div丟了腫么辦  
本文主要介紹了vue3在項(xiàng)目中的邏輯抽離和字段顯示,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

邏輯分層

我們?cè)谑褂胿ue3開發(fā)項(xiàng)目的時(shí)候,
如何進(jìn)行【區(qū)域分層】呢????
舉一個(gè)簡單的小粒子
一個(gè)區(qū)域有【查詢邏輯、修改后的保存邏輯、新增邏輯、刪除邏輯】
這個(gè)頁面可能還有其他的區(qū)域。A區(qū)域、B區(qū)域,C區(qū)域...【有很多邏輯】
這個(gè)時(shí)候我們可以將一個(gè)區(qū)域的邏輯分離出去

將各個(gè)區(qū)域業(yè)務(wù)分開

export default {
  setup () {
    let {queryDo,addDo,delDO,EditDo}=allFun();
    queryDo();//查詢接口就會(huì)被調(diào)用了
  
  }
}

// 這個(gè)是頁面A區(qū)域的邏輯
function allFun(){
  console.log('我是 allFun 函數(shù)內(nèi)的直接語句我將會(huì)被執(zhí)行' )
  function queryDo(){
    console.log('我是查詢接口,調(diào)用后端的數(shù)據(jù)')
  }
  function addDo(){
    console.log('我是新增')
  }
  function delDO(){
    console.log('我是刪除')
  }
  function EditDo(){
    console.log('我是編輯接口')
  }
  return {queryDo,addDo,delDO,EditDo}
}
</script>

這樣做的優(yōu)勢

  • 當(dāng)我們看見 allFun函數(shù)的時(shí)候。
  • 我們就可以知道這個(gè)區(qū)域的所有邏輯
  • 包含crud。方便后期的維護(hù)

這樣的場景應(yīng)該如何處理

在我們寫業(yè)務(wù)邏輯的時(shí)候,
我們最后發(fā)現(xiàn) A和B兩個(gè)區(qū)域都需要調(diào)用同一個(gè)接口
但是由于A區(qū)域已經(jīng)寫好了這個(gè)被調(diào)用的接口
這個(gè)時(shí)候我就想直接去調(diào)用A區(qū)域中的接口

<script>
export default {
  setup () {
    // 這里使用的是結(jié)構(gòu),A區(qū)域
    let {queryDo,addDo,delDO,EditDo}=aAreaAllFun();

    // B區(qū)域
    let {querHander}=bAreaAllFun();

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

// 這個(gè)是A區(qū)域頁面某個(gè)區(qū)域的邏輯
function aAreaAllFun(){
  function queryDo(){
    console.log('我是A區(qū)域的查詢接口')
  }
  function addDo(){
    console.log('我是新增')
  }
  function delDO(){
    console.log('我是刪除')
  }
  function EditDo(){
    console.log('我是編輯接口')
  }
  return {queryDo,addDo,delDO,EditDo}
}

// 這是B區(qū)域的業(yè)務(wù)邏輯
function bAreaAllFun(){
  // 直接去調(diào)用A區(qū)域的查詢接口
  aAreaAllFun().queryDo();

  function querHander(){
    console.log("B區(qū)域的查詢接口")
  }
 
  return {querHander}
}
</script>

雖然使用
aAreaAllFun().queryDo();
直接去調(diào)用A區(qū)域的查詢接口
解決了問題
但是這樣產(chǎn)生了一個(gè)新的問題是
查詢接口被包含在了A區(qū)域;
最后的做法是查詢接口應(yīng)該單獨(dú)抽離出去,
這樣也方便后期我們的維護(hù)

優(yōu)化

<script>
export default {
  setup () {
     // 這個(gè)是A區(qū)域頁面某個(gè)區(qū)域的邏輯
    let {addDo,delDO,EditDo}=aAreaAllFun()
    
    // 這個(gè)是B區(qū)域頁面某個(gè)區(qū)域的邏輯
    let {querHander}=bAreaAllFun();

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

// 公共的查詢接口 很多區(qū)域可能會(huì)使用
function queryDo(){
  console.log('我是區(qū)域的查詢接口,我被抽離出去了')
}

// 這個(gè)是A區(qū)域頁面某個(gè)區(qū)域的邏輯
function aAreaAllFun(){
 
  function addDo(){
    console.log('我是新增')
  }
  function delDO(){
    console.log('我是刪除')
  }
  function EditDo(){
    console.log('我是編輯接口')
  }
  return {addDo,delDO,EditDo}
}

// 這是B區(qū)域的業(yè)務(wù)邏輯
function bAreaAllFun(){
  // 直接去調(diào)用公共的查詢接口
   queryDo();

  function querHander(){
    console.log("B區(qū)域的查詢接口")
  }
 
  return {querHander}
}
</script>

reactive 不一定非要寫在setup函數(shù)中

很多的小伙伴以為reactive一定要寫在setup函數(shù)中
其實(shí)不是這樣的哈
它可以寫在你需要的地方
比如下面的aAreaAllFun函數(shù)中可以使用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}
  }
}
// 這個(gè)是A區(qū)域頁面某個(gè)區(qū)域的邏輯
function aAreaAllFun(){
  let areaData=reactive({
    info:{
      name:'張三',
      age:20,
      sex:'男'
    }
  })
  function addDo(){
    console.log('我是新增')
  }
  return {addDo,areaData}
}
</script>

如何在頁面上直接顯示值

在上面這個(gè)例子中
我們想要實(shí)現(xiàn)姓名、年齡、和性別
我們需要 areaData.info.xxx
這樣做太麻煩了,我們需要優(yōu)化一下

<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}
  }
}
// 這個(gè)是A區(qū)域頁面某個(gè)區(qū)域的邏輯
function aAreaAllFun(){
  let areaData=reactive({
    info:{
      name:'張三',
      age:20,
      sex:'男'
    }
  })

  function ChangeCont(){
    // 這樣更改值,視圖上是不會(huì)響應(yīng)的哈【錯(cuò)誤的】
    // areaData.info={
    //   name:'李四',
    //   age:21,
    //   sex:'男'
    // }

    // 這樣是可以的正確跟新視圖的 【ok的】
    areaData.info.name='123'
    areaData.info.age=12
    areaData.info.sex='男'
  }

  //   toRefs 可以把一個(gè)響應(yīng)式對(duì)象轉(zhuǎn)換為普通的對(duì)象。
  // 該普通對(duì)象的每一個(gè)值都是ref。
  // 由于變成了ref,所以我們需要使用value。
  return {ChangeCont,...toRefs(areaData.info)}
}
</script>

到此這篇關(guān)于淺談vue3在項(xiàng)目中的邏輯抽離和字段顯示的文章就介紹到這了,更多相關(guān)vue3 邏輯抽離和字段顯示內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解elementui之el-image-viewer(圖片查看器)

    詳解elementui之el-image-viewer(圖片查看器)

    這篇文章主要介紹了詳解elementui之el-image-viewer(圖片查看器),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • vue地址欄直接輸入路由無效問題的解決

    vue地址欄直接輸入路由無效問題的解決

    這篇文章主要介紹了vue地址欄直接輸入路由無效問題的解決,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-11-11
  • Vue彈窗組件的實(shí)現(xiàn)方法

    Vue彈窗組件的實(shí)現(xiàn)方法

    這篇文章主要為大家詳細(xì)介紹了Vue彈窗組件的實(shí)現(xiàn)方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-09-09
  • 關(guān)于vue中使用three.js報(bào)錯(cuò)的解決方法

    關(guān)于vue中使用three.js報(bào)錯(cuò)的解決方法

    最近因?yàn)閠hree.js的項(xiàng)目要用Vue.js,下面這篇文章主要給大家介紹了關(guān)于vue中使用three.js報(bào)錯(cuò)的解決方法,文中通過圖文以及示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-03-03
  • unplugin-auto-import的配置以及eslint報(bào)錯(cuò)解決詳解

    unplugin-auto-import的配置以及eslint報(bào)錯(cuò)解決詳解

    unplugin-auto-import?解決了vue3-hook、vue-router、useVue等多個(gè)插件的自動(dòng)導(dǎo)入,也支持自定義插件的自動(dòng)導(dǎo)入,是一個(gè)功能強(qiáng)大的typescript支持工具,這篇文章主要給大家介紹了關(guān)于unplugin-auto-import的配置以及eslint報(bào)錯(cuò)解決的相關(guān)資料,需要的朋友可以參考下
    2022-08-08
  • Vue-Element-Admin集成自己的接口實(shí)現(xiàn)登錄跳轉(zhuǎn)

    Vue-Element-Admin集成自己的接口實(shí)現(xiàn)登錄跳轉(zhuǎn)

    關(guān)于這個(gè)Vue-element-admin中的流程可能對(duì)于新的同學(xué)不是很友好,所以本文將結(jié)合實(shí)例代碼,介紹Vue-Element-Admin集成自己的接口實(shí)現(xiàn)登錄跳轉(zhuǎn),感興趣的小伙伴們可以參考一下
    2021-06-06
  • 解決vue單頁使用keep-alive頁面返回不刷新的問題

    解決vue單頁使用keep-alive頁面返回不刷新的問題

    下面小編就為大家分享一篇解決vue單頁使用keep-alive頁面返回不刷新的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • Vue移動(dòng)端下拉刷新組件的使用教程

    Vue移動(dòng)端下拉刷新組件的使用教程

    這篇文章主要介紹了Vue移動(dòng)端下拉刷新組件的使用教程,每一次我在使用vant組件庫里面list組件和下拉刷新連在一起用的時(shí)候都會(huì)出現(xiàn)下拉刷新和列表下滑局部滾動(dòng)的沖突,這就很難受,這篇文章將解決它
    2023-04-04
  • vue實(shí)現(xiàn)動(dòng)態(tài)進(jìn)度條效果

    vue實(shí)現(xiàn)動(dòng)態(tài)進(jìn)度條效果

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)動(dòng)態(tài)進(jìn)度條效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • web前端vue實(shí)現(xiàn)插值文本和輸出原始html

    web前端vue實(shí)現(xiàn)插值文本和輸出原始html

    這篇文章主要介紹了web前端vue實(shí)現(xiàn)插值文本和輸出原始html,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-01-01

最新評(píng)論