淺談vue3在項目中的邏輯抽離和字段顯示
邏輯分層
我們在使用vue3開發(fā)項目的時候,
如何進行【區(qū)域分層】呢????
舉一個簡單的小粒子
一個區(qū)域有【查詢邏輯、修改后的保存邏輯、新增邏輯、刪除邏輯】
這個頁面可能還有其他的區(qū)域。A區(qū)域、B區(qū)域,C區(qū)域...【有很多邏輯】
這個時候我們可以將一個區(qū)域的邏輯分離出去
將各個區(qū)域業(yè)務(wù)分開
export default {
setup () {
let {queryDo,addDo,delDO,EditDo}=allFun();
queryDo();//查詢接口就會被調(diào)用了
}
}
// 這個是頁面A區(qū)域的邏輯
function allFun(){
console.log('我是 allFun 函數(shù)內(nèi)的直接語句我將會被執(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)勢
- 當我們看見 allFun函數(shù)的時候。
- 我們就可以知道這個區(qū)域的所有邏輯
- 包含crud。方便后期的維護
這樣的場景應該如何處理
在我們寫業(yè)務(wù)邏輯的時候,
我們最后發(fā)現(xiàn) A和B兩個區(qū)域都需要調(diào)用同一個接口
但是由于A區(qū)域已經(jīng)寫好了這個被調(diào)用的接口
這個時候我就想直接去調(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}
}
}
// 這個是A區(qū)域頁面某個區(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)生了一個新的問題是
查詢接口被包含在了A區(qū)域;
最后的做法是查詢接口應該單獨抽離出去,
這樣也方便后期我們的維護
優(yōu)化
<script>
export default {
setup () {
// 這個是A區(qū)域頁面某個區(qū)域的邏輯
let {addDo,delDO,EditDo}=aAreaAllFun()
// 這個是B區(qū)域頁面某個區(qū)域的邏輯
let {querHander}=bAreaAllFun();
return {queryDo,addDo,delDO,EditDo,querHander}
}
}
// 公共的查詢接口 很多區(qū)域可能會使用
function queryDo(){
console.log('我是區(qū)域的查詢接口,我被抽離出去了')
}
// 這個是A區(qū)域頁面某個區(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ù)中
其實不是這樣的哈
它可以寫在你需要的地方
比如下面的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}
}
}
// 這個是A區(qū)域頁面某個區(qū)域的邏輯
function aAreaAllFun(){
let areaData=reactive({
info:{
name:'張三',
age:20,
sex:'男'
}
})
function addDo(){
console.log('我是新增')
}
return {addDo,areaData}
}
</script>
如何在頁面上直接顯示值
在上面這個例子中
我們想要實現(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}
}
}
// 這個是A區(qū)域頁面某個區(qū)域的邏輯
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 可以把一個響應式對象轉(zhuǎn)換為普通的對象。
// 該普通對象的每一個值都是ref。
// 由于變成了ref,所以我們需要使用value。
return {ChangeCont,...toRefs(areaData.info)}
}
</script>
到此這篇關(guān)于淺談vue3在項目中的邏輯抽離和字段顯示的文章就介紹到這了,更多相關(guān)vue3 邏輯抽離和字段顯示內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue.js獲取被選擇的option的value和text值方法
今天小編就為大家分享一篇Vue.js獲取被選擇的option的value和text值方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08
vue3+ElementPlus+VueCropper實現(xiàn)上傳圖片功能
文章介紹了如何在Vue3、ElementPlus和VueCropper組件中實現(xiàn)圖片上傳和裁剪功能,包括放大、縮小等操作,感興趣的朋友跟隨小編一起看看吧2025-01-01
antd form表單使用setFildesValue 賦值失效的解決
這篇文章主要介紹了antd form表單使用setFildesValue 賦值失效的解決方案,具有很好的參考價值,希望對大家有所幫助。2023-04-04
vue?echarts實現(xiàn)改變canvas長和寬自適應
這篇文章主要介紹了vue?echarts實現(xiàn)改變canvas長和寬自適應問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04

