淺談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 邏輯抽離和字段顯示內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- 詳解Vue3中setup函數的使用教程
- vue3.0 Reactive數據更新頁面沒有刷新的問題
- 前端vue3 setup使用教程
- vue3常用的API使用簡介
- Vue3如何理解ref toRef和toRefs的區別