Vue3如何清空Reactive定義的數(shù)組
vue3清空Reactive定義的數(shù)組
shallowRef 定義得數(shù)組 清空
let component_list = shallowRef([
{unit: Head, name: 'Head', id: 1},
{unit: TopClass, name: 'TopClass', id: 2},
])
component_list.value.length = [] // 清空定義數(shù)據(jù)打印圖片:

清空數(shù)組 數(shù)據(jù) 圖片 (達(dá)到預(yù)期目的):

vue3 reactive的坑
最近使用vue3的過(guò)程中發(fā)現(xiàn)reactive有一些問(wèn)題
1.清空reactive定義的數(shù)組時(shí)必須將length設(shè)為0,直接賦值一個(gè)空數(shù)組是沒(méi)有作用的,同理對(duì)象直接賦值一個(gè)空對(duì)象也沒(méi)有作用,只能遍歷對(duì)象一項(xiàng)一項(xiàng)刪,這里說(shuō)的沒(méi)有作用是不能響應(yīng)式的更新頁(yè)面,如果打印一下是能看到確實(shí)被刪除了,但是頁(yè)面沒(méi)有變化
清空數(shù)組
// 錯(cuò)誤示例
<template>
<div>{{ arr }}</div>
<button @click="click">點(diǎn)擊</button>
</template>
<script setup>
import { reactive } from 'vue'
let arr = reactive([1, 2, 3])
const click = () => {
arr = []
console.log(arr) // 這里打印的結(jié)果是正常的空數(shù)組
}
</script>// 正確示例
<template>
<div>{{ arr }}</div>
<button @click="click">點(diǎn)擊</button>
</template>
<script setup>
import { reactive } from 'vue'
let arr = reactive([1, 2, 3])
const click = () => {
arr.length = 0 // 這里和vue2是正好相反,vue2直接將數(shù)組length設(shè)為0是無(wú)效的
console.log(arr)
}
</script>清空對(duì)象
// 錯(cuò)誤示例
<template>
<div>{{ obj }}</div>
<button @click="click">點(diǎn)擊</button>
</template>
<script setup>
import { reactive } from 'vue'
let obj = reactive({a: 111, b: 222})
const click = () => {
obj = {}
console.log(obj) // 這里打印的結(jié)果是正常的空對(duì)象
}
</script>// 錯(cuò)誤示例
<template>
<div>
<div>{{ obj }}</div>
<button @click="click">點(diǎn)擊</button>
</div>
</template>
<script setup>
import { reactive } from 'vue'
let arr = reactive({a: xxx, b: xxx })
const click = () => {
for (let i in obj) {
delete obj[i]
}
console.log(obj) // 這里打印的結(jié)果是正常的空數(shù)組
}
</script>2.同樣的道理直接賦值也不行,數(shù)組只能用數(shù)組的某些方法,或者直接修改索引,修改索引跟vue2又是相反,vue2只修改索引項(xiàng)沒(méi)有作用,對(duì)象直接使用點(diǎn)語(yǔ)法即可,直接賦一個(gè)對(duì)象沒(méi)有作用
3.這些問(wèn)題其實(shí)只要使用ref就可以解決,但是人官方推薦使用reactive。。。。
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- vue3中reactive的對(duì)象清空所引發(fā)的問(wèn)題解決方案(清空不了和清空之后再去賦值就賦值不了)
- Vue.js實(shí)現(xiàn)輸入框清空功能的兩種方式
- vue前端更新后需要清空緩存代碼示例
- vue3清空reactive的四種方式
- vue中el-date-picker type=daterange日期清空時(shí)不回顯的解決
- vue返回首頁(yè)后如何清空路由問(wèn)題
- ant design vue 清空upload組件圖片緩存的問(wèn)題
- vue如何實(shí)現(xiàn)清空this.$route.query的值
- vue清空f(shuō)orm對(duì)象的方法
- vue3清空l(shuí)et?arr?=?reactive([])的實(shí)現(xiàn)示例
相關(guān)文章
vue中使用echarts實(shí)現(xiàn)動(dòng)態(tài)數(shù)據(jù)綁定以及獲取后端接口數(shù)據(jù)
總結(jié)一下自己最近項(xiàng)目中用echarts動(dòng)態(tài)獲取接口數(shù)據(jù)并畫圖的方法,下面這篇文章主要給大家介紹了關(guān)于vue中使用echarts實(shí)現(xiàn)動(dòng)態(tài)數(shù)據(jù)綁定以及獲取后端接口數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下2022-07-07
vue打包后出現(xiàn)空白頁(yè)的原因及解決方式詳解
在項(xiàng)目中很多時(shí)候需要用到vue打包成html不需要放在服務(wù)器上就能瀏覽,根據(jù)官網(wǎng)打包出來(lái)的html直接打開(kāi)是顯示空白,下面這篇文章主要給大家介紹了關(guān)于vue打包后出現(xiàn)空白頁(yè)的原因及解決方式的相關(guān)資料,需要的朋友可以參考下2022-07-07
vue中使用keep-alive動(dòng)態(tài)刪除已緩存組件方式
這篇文章主要介紹了vue中使用keep-alive動(dòng)態(tài)刪除已緩存組件方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08
vue?如何綁定disabled屬性讓其不能被點(diǎn)擊
這篇文章主要介紹了vue?如何綁定disabled屬性讓其不能被點(diǎn)擊,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04
基于vue3.0.1beta搭建仿京東的電商H5項(xiàng)目
這篇文章主要介紹了基于vue3.0.1beta搭建仿京東的電商H5項(xiàng)目,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05

