欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue3中給數(shù)組賦值丟失響應(yīng)式的解決

 更新時(shí)間:2023年04月19日 15:19:40   作者:凡小多  
這篇文章主要介紹了vue3中給數(shù)組賦值丟失響應(yīng)式的解決方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

vue3給數(shù)組賦值丟失響應(yīng)式的解決

由于vue3使用proxy,對(duì)于對(duì)象和數(shù)組都不能直接整個(gè)賦值。

只有push或者根據(jù)索引遍歷賦值才可以保留reactive數(shù)組的響應(yīng)性

const arr = reactive([]);
 
const load = () => {
  const res = [2, 3, 4, 5]; //假設(shè)請(qǐng)求接口返回的數(shù)據(jù)
  // 方法1 失敗,直接賦值丟失了響應(yīng)性
  // arr = res;
  // 方法2 這樣也是失敗
  // arr.concat(res);
  // 方法3 可以,但是很麻煩
  res.forEach(e => {
    arr.push(e);
  });
  // 方法4 可以
  // arr.length = 0 // 清空原數(shù)組
  arr.push(...res)
}

或者

const state = reactive({
	arr: []
});
...
state.arr = res
...

或者

const state = ref([]);
...
state.value= res
...

例子

<template>
    <div class="content">
		...
        <Card title="content組件">
            <button @click.prevent="add">ADD</button>
            <button @click.prevent="pop">POP</button>
            <button @click.prevent="changeList">changeList</button>
            {{ list }}
            <ProInj></ProInj>
        </Card>
    </div>
</template>

<script setup lang="ts">
import { reactive, markRaw, ref, defineAsyncComponent, inject, Ref } from 'vue'
...
let flag = ref(true)

let list = inject<Ref<number[]>>('list',ref(reactive<number[]>([])))
// let list = inject<Ref<number[]>>('list', ref<number[]>([1, 2, 3]))
const add = () => list.push(list!.length + 1)
const pop = () => list.pop()

const changeList = () => {
    flag.value = !flag.value
    if (flag.value) {
        list.length = 0
        list.push(...[9, 5, 4, 1])
    }
    else {
        list.length = 0
        list.push(...[6, 6, 6, 6, 6])
    }
}
...
</script>

<style lang="less" scoped>
...
</style>

效果圖:

reactive響應(yīng)式數(shù)據(jù)賦值丟失響應(yīng)式問題

reactive響應(yīng)式數(shù)據(jù)賦值問題

const ?list = reactive({})

當(dāng)你接收到接口數(shù)據(jù),不要直接賦值 比如 list = data

這樣會(huì)丟失響應(yīng)式!

你可以這樣做:

?? ?const ?list = reactive({
?? ?arr:[]
})

list.arr = data.arr

或者

將list聲明為ref方式

const list = ref([])
list.value = data

這樣也不會(huì)丟失響應(yīng)式

原因:reactive聲明的響應(yīng)式對(duì)象被list代理  操作代理對(duì)象需要有代理對(duì)象的前綴,直接覆蓋會(huì)丟失響應(yīng)式 

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 使用Vite搭建vue3+TS項(xiàng)目的實(shí)現(xiàn)步驟

    使用Vite搭建vue3+TS項(xiàng)目的實(shí)現(xiàn)步驟

    本文主要介紹了使用Vite搭建vue3+TS項(xiàng)目的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • vue3內(nèi)嵌iframe的傳參與接收參數(shù)代碼示例

    vue3內(nèi)嵌iframe的傳參與接收參數(shù)代碼示例

    這篇文章主要給大家介紹了關(guān)于vue3內(nèi)嵌iframe的傳參與接收參數(shù)的相關(guān)資料,Vue項(xiàng)目中使用iframe及傳值功能相信有不少人都遇到過,需要的朋友可以參考下
    2023-07-07
  • vue完美實(shí)現(xiàn)el-table列寬自適應(yīng)

    vue完美實(shí)現(xiàn)el-table列寬自適應(yīng)

    這篇文章主要介紹了vue完美實(shí)現(xiàn)el-table列寬自適應(yīng),對(duì)vue感興趣的同學(xué),可以參考下
    2021-05-05
  • vite多頁面配置項(xiàng)目實(shí)戰(zhàn)

    vite多頁面配置項(xiàng)目實(shí)戰(zhàn)

    vite官方文檔中有關(guān)于多頁面應(yīng)用模式如果配置的說明,下面這篇文章主要給大家介紹了關(guān)于vite多頁面配置的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-04-04
  • vue項(xiàng)目實(shí)現(xiàn)表單登錄頁保存賬號(hào)和密碼到cookie功能

    vue項(xiàng)目實(shí)現(xiàn)表單登錄頁保存賬號(hào)和密碼到cookie功能

    這篇文章主要介紹了vue項(xiàng)目實(shí)現(xiàn)表單登錄頁保存賬號(hào)和密碼到cookie功能,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-08-08
  • 關(guān)于Pinia狀態(tài)管理解讀

    關(guān)于Pinia狀態(tài)管理解讀

    這篇文章主要介紹了Pinia狀態(tài)管理解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • 解決element?ui?cascader?動(dòng)態(tài)加載回顯問題

    解決element?ui?cascader?動(dòng)態(tài)加載回顯問題

    這篇文章主要介紹了element?ui?cascader?動(dòng)態(tài)加載回顯問題解決方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-08-08
  • ElementUI中el-dropdown-item點(diǎn)擊事件無效問題

    ElementUI中el-dropdown-item點(diǎn)擊事件無效問題

    這篇文章主要介紹了ElementUI中el-dropdown-item點(diǎn)擊事件無效問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • vue表格顯示字符串過長(zhǎng)的問題及解決

    vue表格顯示字符串過長(zhǎng)的問題及解決

    這篇文章主要介紹了vue表格顯示字符串過長(zhǎng)的問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • Vue項(xiàng)目接入Paypal實(shí)現(xiàn)示例詳解

    Vue項(xiàng)目接入Paypal實(shí)現(xiàn)示例詳解

    這篇文章主要介紹了Vue項(xiàng)目接入Paypal實(shí)現(xiàn)示例詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06

最新評(píng)論