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>


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM