「這是我參與8月更文挑戰的第6天,活動詳情查看:8月更文挑戰」vue
咱們在使用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函數中
其實不是這樣的哈
它能夠寫在你須要的地方
好比下面的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>
複製代碼