vue3使用reactive賦值后頁面不改變
場景原因
我們需要在vue3中使用服務(wù)器的數(shù)據(jù)渲染到頁面上,我使用的是reactive生成的響應(yīng)式數(shù)據(jù)屬性,但是在掛載后請求的數(shù)據(jù)并沒有渲染顯示到頁面上。
技術(shù):
vue3、element-ui-plus
一、例子
home.vue
<template>
<div class="common-layout">
<el-menu @select="changeMenu" :collapse="isCollapse" active-text-color="#409eff" background-color="#333744"
class="el-menu-vertical-demo" default-active="2" text-color="#fff" :unique-opened="true">
<el-sub-menu :index="item.path" v-for="(item) in parmar.menus" :key="item.id">
<template #title>
<el-icon>
<List />
</el-icon>
<span>{{ item.authName }}</span>
</template>
<el-menu-item :index="item2.path" v-for="(item2) in item.children" :key="item2.id">
<el-icon>
<Menu />
</el-icon>
{{ item2.authName }}
</el-menu-item>
</el-sub-menu>
</el-menu>
</div>
</template>
<script setup>
// 引入模塊
import { reactive, onMounted } from 'vue'
import { useRouter } from 'vue-router'
import http from '@/utils/request'
const router = useRouter();
let menusList = reactive([
]);
onMounted(() => {
getData()
})
const getData = async () => {
let { data } = await http.get('/menus');
// 這里直接賦值,會導(dǎo)致menusList失去響應(yīng)式了
menusList = data.data;
console.log(menusList);
}
const changeMenu = (key) => {
router.push('/home/' + key)
}
</script>
<style lang="less" scoped>
.common-layout {
height: 100vh;
box-sizing: border-box;
position: relative;
overflow: hidden;
/deep/.el-menu--vertical {
margin: 0;
border-right: none !important;
overflow-x: hidden;
height: calc(100vh - 100px);
user-select: none;
}
.el-menu-vertical-demo:not(.el-menu--collapse) {
width: 200px;
min-height: 400px;
}
}
</style>
我們通過直接賦值,可以看出數(shù)據(jù)變?yōu)槠胀ǖ臄?shù)據(jù)了,并不是響應(yīng)式的。
二、解決方法
1、使用ref存儲響應(yīng)式數(shù)據(jù)
代碼如下:
<script setup>
// 引入模塊
import { ref, reactive, onMounted } from 'vue'
import http from '@/utils/request'
let menusList = ref([
]);
onMounted(() => {
getData()
})
const getData = async () => {
let { data } = await http.get('/menus');
// 這里直接賦值value,在頁面上直接使用menusList即可!
menusList.value = data.data;
}
</script>
可以看出打印出的數(shù)據(jù)是經(jīng)過ref劫持的數(shù)據(jù),是響應(yīng)式的。
2、在reactive中使用對象包裹要改變的數(shù)據(jù)
代碼如下:
<script setup>
// 引入模塊
import { reactive, onMounted } from 'vue'
import http from '@/utils/request'
let parmar = reactive({
menus: [
]
});
onMounted(() => {
getData()
})
const getData = async () => {
let { data } = await http.get('/menus');
// 這里直接賦值對象里面的數(shù)據(jù),就不會造成把響應(yīng)式替換掉的情況了,直接在頁面上通過parmar.menus使用數(shù)據(jù)!
parmar.menus = data.data;
console.log( parmar);
}
</script>
使用這種方式,數(shù)據(jù)也是響應(yīng)式的。
3、for of循環(huán)push到reactive數(shù)據(jù)中,不破壞數(shù)據(jù)結(jié)構(gòu)
代碼如下:
<script setup>
// 引入模塊
import { reactive, onMounted } from 'vue'
import http from '@/utils/request'
let menusList = reactive([])
onMounted(() => {
getData()
})
const getData = async () => {
let { data } = await http.get('/menus');
for (let i of data.data){
menusList.push(i);
}
console.log(menusList);
}
</script>
總結(jié)
主要的問題就是使用
reactive生成的響應(yīng)式數(shù)據(jù),在直接賦值時把響應(yīng)式數(shù)據(jù)給替換為了普通數(shù)據(jù)了,導(dǎo)致無法監(jiān)聽數(shù)據(jù)的變化。
到此這篇關(guān)于vue3使用reactive賦值后頁面不改變的文章就介紹到這了,更多相關(guān)vue3 reactive賦值內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解決Vue.js應(yīng)用回退或刷新界面時提示用戶保存修改問題
這篇文章主要介紹了Vue.js應(yīng)用回退或刷新界面時提示用戶保存修改問題,本文通過兩種手段防止運營編輯時丟失數(shù)據(jù),具體內(nèi)容詳情,感興趣的朋友跟隨小編一起看看吧2019-11-11
Vue+Jwt+SpringBoot+Ldap完成登錄認證的示例代碼
本篇文章主要介紹了Vue+Jwt+SpringBoot+Ldap完成登錄認證的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-05-05
vue.js使用v-model實現(xiàn)表單元素(input) 雙向數(shù)據(jù)綁定功能示例
這篇文章主要介紹了vue.js使用v-model實現(xiàn)表單元素(input) 雙向數(shù)據(jù)綁定功能,結(jié)合完整實例形式分析了v-model實現(xiàn)表單input元素數(shù)據(jù)雙向綁定相關(guān)操作技巧,需要的朋友可以參考下2019-03-03
Vue+SpringBoot實現(xiàn)支付寶沙箱支付的示例代碼
本文主要介紹了Vue+SpringBoot實現(xiàn)支付寶沙箱支付的示例代碼,文中通過示例代碼介紹的非常詳細,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-06-06
vue 1.0 結(jié)合animate.css定義動畫效果
本文分步驟給大家介紹了Vue 1.0自定義動畫效果,vue1.0代碼結(jié)合animate.css定義動畫,頁面一定要引入animate.cdd,具體實例代碼大家參考下本文2018-07-07
vue最強table vxe-table 虛擬滾動列表 前端導(dǎo)出問題分析
最近遇到個問題,后臺一次性返回2萬條列表數(shù)據(jù)并且需求要求所有數(shù)據(jù)必須全部展示,不能做假分頁,怎么操作呢,下面通過本文介紹下vue最強table vxe-table 虛擬滾動列表 前端導(dǎo)出問題,感興趣的朋友一起看看吧2023-10-10
vue Element-ui表格實現(xiàn)樹形結(jié)構(gòu)表格
這篇文章主要為大家詳細介紹了vue Element-ui表格實現(xiàn)樹形結(jié)構(gòu)表格,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-06-06

