Vue3中使用reactive時(shí),后端有返回?cái)?shù)據(jù)但dom沒(méi)有更新的解決
使用reactive時(shí),后端有返回?cái)?shù)據(jù)但dom沒(méi)有更新
問(wèn)題
在Vue3的setup中使用reactive更新數(shù)據(jù),但是dom沒(méi)有更新問(wèn)題
代碼:
<template>
<div class="aside">
<div class="collpase-btn" @click="collpaseMenu">
<el-icon><fold /></el-icon>
</div>
<el-menu
active-text-color="#ffd04b"
background-color="#545c64"
class="el-menu-vertical-demo"
default-active="2"
text-color="#fff"
:collapse="store.state.isCollapse"
@open="handleOpen"
@close="handleClose"
>
<el-sub-menu :index="item.id" v-for="item in menus" :key="item.id">
<template #title>
<el-icon><grid /></el-icon>
<span>{{item.title}}</span>
</template>
<el-menu-item :index="it.id" v-for="it in item.subMenuList">{{it.title}}</el-menu-item>
</el-sub-menu>
</el-menu>
</div>
</template>
<script lang="ts">
import axios from 'axios';
import { defineComponent, onMounted, reactive } from 'vue'
import { useStore } from 'vuex';
export default defineComponent({
name:'Aside',
setup() {
const store = useStore();
const mensList:any = [];
let menus = reactive(mensList);
const handleOpen = (key: string, keyPath: string[]) => {
}
const handleClose = (key: string, keyPath: string[]) => {
};
const collpaseMenu = () => {
store.dispatch('collpaseChange');
};
onMounted(() => {
axios.get('/user/menu').then(res => {
menus.mensList = res.data.menusList;
});
});
return {
handleOpen,
handleClose,
collpaseMenu,
store,
menus
}
},
})
</script>
<style lang="scss" scoped>
.el-menu-item.is-active{
background-color: var(--el-menu-hover-bg-color);;
}
.collpase-btn{
text-align: center;
width: 100%;
padding: 10px 0px;
cursor: pointer;
.el-icon{
color: white;
font-size: 24px;
}
}
</style>
直接使用reactive()一個(gè)空數(shù)組,改變當(dāng)前值時(shí),頁(yè)面不會(huì)自動(dòng)刷新。
解決辦法
使用reactive時(shí),將參數(shù)變?yōu)橐粋€(gè)對(duì)象形式,而不是單純的數(shù)組。

當(dāng)改為傳入對(duì)象包裹后,頁(yè)面正常顯示:

關(guān)于vue3中reactive的意義
在學(xué)習(xí)Vue3的時(shí)候產(chǎn)生疑問(wèn):
const addForm = reactive({ // 這里面的reactive啥意思
? sysPre: null,
? diaPre: null,
? tem: null
})查詢(xún)解決
在Vue3中,響應(yīng)式對(duì)象是指通過(guò)reactive函數(shù)轉(zhuǎn)換而來(lái)的對(duì)象,它的屬性可以被Vue自動(dòng)監(jiān)測(cè),當(dāng)屬性值發(fā)生變化時(shí),Vue會(huì)自動(dòng)更新相關(guān)的視圖。這個(gè)過(guò)程是通過(guò)Vue內(nèi)部實(shí)現(xiàn)的響應(yīng)式系統(tǒng)來(lái)完成的。
響應(yīng)式對(duì)象的意義在于使得開(kāi)發(fā)者可以更加方便地管理和操作數(shù)據(jù)。當(dāng)數(shù)據(jù)被轉(zhuǎn)換為響應(yīng)式對(duì)象后,我們可以直接修改對(duì)象的屬性值,而不需要手動(dòng)調(diào)用Vue的更新函數(shù)來(lái)更新視圖。這樣可以極大地提高開(kāi)發(fā)效率,讓開(kāi)發(fā)者更加專(zhuān)注于業(yè)務(wù)邏輯的實(shí)現(xiàn)。
此外,響應(yīng)式對(duì)象還可以與Vue的模板語(yǔ)法、組件等功能無(wú)縫銜接,使得我們可以通過(guò)組合使用響應(yīng)式對(duì)象和Vue的其他功能,快速開(kāi)發(fā)出高效、可維護(hù)的應(yīng)用程序。
在這段代碼中,addForm對(duì)象被使用reactive函數(shù)轉(zhuǎn)換為一個(gè)響應(yīng)式對(duì)象。這意味著當(dāng)addForm對(duì)象的屬性sysPre,diaPre或tem發(fā)生變化時(shí),相關(guān)的依賴(lài)將會(huì)自動(dòng)更新,如綁定在模板中的表單輸入框等。
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue項(xiàng)目中向數(shù)組添加元素的3種方式
這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目中向數(shù)組添加元素的3種方式,在Vue中添加元素到數(shù)組非常簡(jiǎn)單,文中通過(guò)代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用vue具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-10-10
vuex頁(yè)面刷新導(dǎo)致數(shù)據(jù)丟失的解決方案
這篇文章主要介紹了vuex頁(yè)面刷新導(dǎo)致數(shù)據(jù)丟失的解決方案,幫助大家更好的使用vue框架,感興趣的朋友可以了解下2020-12-12
vue本地打開(kāi)build后生成的dist文件夾index.html問(wèn)題
這篇文章主要介紹了vue本地打開(kāi)build后生成的dist文件夾index.html問(wèn)題,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2019-09-09
vue實(shí)現(xiàn)二級(jí)導(dǎo)航欄效果
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)二級(jí)導(dǎo)航欄效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-10-10
Vue3+Elementplus實(shí)現(xiàn)面包屑功能
這篇文章主要為大家詳細(xì)介紹了Vue3如何結(jié)合Elementplus實(shí)現(xiàn)面包屑功能,文中的示例代碼簡(jiǎn)潔易懂,具有一定的借鑒價(jià)值,有需要的小伙伴可以參考下2023-11-11
Vue組件通信中非父子組件傳值知識(shí)點(diǎn)總結(jié)
在本篇文章里小編給大家整理的是關(guān)于Vue組件通信中非父子組件傳值知識(shí)點(diǎn)總結(jié),有興趣的朋友們學(xué)習(xí)下。2019-12-12
詳解解決使用axios發(fā)送json后臺(tái)接收不到的問(wèn)題
這篇文章主要介紹了詳解解決使用axios發(fā)送json后臺(tái)接收不到的問(wèn)題,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-06-06

