亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue3-reactive定義的對(duì)象數(shù)組如何賦值

 更新時(shí)間:2025年06月16日 09:20:14   作者:檸檬樹^-^  
這篇文章主要介紹了vue3-reactive定義的對(duì)象數(shù)組如何賦值問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

vue3-reactive定義的對(duì)象數(shù)組賦值

type childEditQosItem = {
objectName: string;
attribute: string;
type: string;
valueType: string;
value: string;
};
const ruleList = reactive<childEditQosItem>([
{ objectName: "", attribute: "", type: "", valueType: "", value: "" },
]);

const data = [
{ attribute: "2", type: "3", valueType: "4", value: "6" },
{ objectName: "7", attribute: "8", type: "9", valueType: "" },
];

data 數(shù)組中的元素補(bǔ)充完整并更新到 ruleList 中。

思路

  • 類型定義:和之前一樣,先定義了 childEditQosItem 類型,明確每個(gè)元素應(yīng)該包含的屬性。
  • 創(chuàng)建響應(yīng)式數(shù)組 ruleList:使用 reactive 函數(shù)創(chuàng)建響應(yīng)式數(shù)組并初始化了一個(gè)默認(rèn)元素。
  • 清空 ruleList:使用 splice 方法將 ruleList 中的元素清空,為后續(xù)添加處理后的數(shù)據(jù)做準(zhǔn)備。

使用 for...in 處理數(shù)據(jù)

  • 外層 for 循環(huán)遍歷 data 數(shù)組中的每個(gè)元素。
  • 對(duì)于每個(gè)元素,先創(chuàng)建一個(gè)默認(rèn)的 newItem 對(duì)象,其屬性都初始化為空字符串。
  • 內(nèi)層 for...in 循環(huán)遍歷當(dāng)前元素的每個(gè)屬性。使用 Object.prototype.hasOwnProperty.call 來確保只處理對(duì)象自身的屬性,避免處理原型鏈上的屬性。
  • 將當(dāng)前元素的屬性值賦值給 newItem 對(duì)應(yīng)的屬性。

更新 ruleList:將處理好的 newItem 添加到 ruleList 中。

const ruleList = reactive([
{ objectName: "", attribute: "", type: "", valueType: "", value: "" },
]);

const data = [
{ attribute: "2", type: "3", valueType: "4", value: "6" },
{ objectName: "7", attribute: "8", type: "9", valueType: "" },
];

// 清空 ruleList 原有的內(nèi)容
ruleList.length = 0;

// 遍歷 data 數(shù)組
for (let i = 0; i < data.length; i++) {
const newItem = {
objectName: "",
attribute: "",
type: "",
valueType: "",
value: ""
};
// 合并 data 中當(dāng)前項(xiàng)的屬性到新對(duì)象
for (const key in data[i]) {
if (data[i].hasOwnProperty(key)) {
newItem[key] = data[i][key];
}
}
ruleList.push(newItem);
}

console.log(ruleList);

這個(gè) TypeScript 錯(cuò)誤提示表明,你試圖使用一個(gè) string 類型的變量 key 來索引 newItem 對(duì)象,但 newItem 類型并沒有定義這樣的索引簽名。

要解決這個(gè)問題

你可以通過類型斷言或者使用類型守衛(wèi)來確保 keynewItem 對(duì)象的合法屬性名。

// 定義 childEditQosItem 類型
type childEditQosItem = {
objectName: string;
attribute: string;
type: string;
valueType: string;
value: string;
};

const ruleList = reactive<childEditQosItem[]>([
{ objectName: "", attribute: "", type: "", valueType: "", value: "" },
]);

const data = [
{ attribute: "2", type: "3", valueType: "4", value: "6" },
{ objectName: "7", attribute: "8", type: "9", valueType: "" },
];

// 清空 ruleList
ruleList.length = 0;

// 定義類型守衛(wèi)函數(shù)
function isValidKey(key: string): key is keyof childEditQosItem {
return ['objectName', 'attribute', 'type', 'valueType', 'value'].includes(key);
}

for (let i = 0; i < data.length; i++) {
const newItem: childEditQosItem = {
objectName: "",
attribute: "",
type: "",
valueType: "",
value: "",
};
for (const key in data[i]) {
if (data[i].hasOwnProperty(key) && isValidKey(key)) {
newItem[key] = data[i][key] || "";
}
}
ruleList.push(newItem);
}

console.log(ruleList);

isValidKey 函數(shù)是一個(gè)類型守衛(wèi),它接受一個(gè) string 類型的參數(shù) key,并檢查 key 是否是 childEditQosItem 類型的合法屬性名。如果是,則返回 true,并且 TypeScript 編譯器會(huì)將 key 的類型縮小為 keyof childEditQosItem

for...in 循環(huán)中,使用 isValidKey(key) 作為類型守衛(wèi),確保只有合法的屬性名才能用于索引 newItem 對(duì)象。

其中

 newItem[key] = data[i][key] || "";

在賦值時(shí)使用 || "" 運(yùn)算符,若 data[i][key] 的值為 undefined 或者空字符串,就會(huì)將空字符串賦給 newItem[key],這樣就保證了賦值的類型是 string

或者:

for (const key in data[i]) {
if (data[i].hasOwnProperty(key) && isValidKey(key)) {
const value = data[i][key];
if (value!== undefined) {
newItem[key] = value;
}
}
}

總結(jié)

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

相關(guān)文章

  • Vue中實(shí)現(xiàn)表單地區(qū)選擇與級(jí)聯(lián)聯(lián)動(dòng)示例詳解

    Vue中實(shí)現(xiàn)表單地區(qū)選擇與級(jí)聯(lián)聯(lián)動(dòng)示例詳解

    這篇文章主要為大家介紹了Vue中實(shí)現(xiàn)表單地區(qū)選擇與級(jí)聯(lián)聯(lián)動(dòng)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-09-09
  • vue實(shí)現(xiàn)圖形驗(yàn)證碼登錄

    vue實(shí)現(xiàn)圖形驗(yàn)證碼登錄

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)圖形驗(yàn)證碼登錄,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-04-04
  • VUE注冊(cè)全局組件和局部組件過程解析

    VUE注冊(cè)全局組件和局部組件過程解析

    這篇文章主要介紹了VUE注冊(cè)全局組件和局部組件過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-10-10
  • vue3.0 Reactive數(shù)據(jù)更新頁(yè)面沒有刷新的問題

    vue3.0 Reactive數(shù)據(jù)更新頁(yè)面沒有刷新的問題

    這篇文章主要介紹了vue3.0 Reactive數(shù)據(jù)更新頁(yè)面沒有刷新的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • 前端架構(gòu)vue架構(gòu)插槽slot使用教程

    前端架構(gòu)vue架構(gòu)插槽slot使用教程

    這篇文章主要為大家介紹了前端vue架構(gòu)插槽slot使用教程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-02-02
  • Element中Slider滑塊的具體使用

    Element中Slider滑塊的具體使用

    這篇文章主要介紹了Element中Slider滑塊的具體使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • vue如何實(shí)現(xiàn)角色權(quán)限的控制

    vue如何實(shí)現(xiàn)角色權(quán)限的控制

    關(guān)于角色與權(quán)限控制,通常是分為兩大類,一種是菜單權(quán)限,一種是操作權(quán)限,本文將深入探討如何通過?Vue?實(shí)現(xiàn)角色權(quán)限控制,特別是基于按鈕級(jí)別的權(quán)限控制,需要的可以了解下
    2025-02-02
  • vue中使用echarts并根據(jù)選擇條件動(dòng)態(tài)展示echarts圖表

    vue中使用echarts并根據(jù)選擇條件動(dòng)態(tài)展示echarts圖表

    雖然老早就看過很多echarts的例子, 但自己接觸的項(xiàng)目中一直都沒有真正用到過,直到最近才開始真正使用,下面這篇文章主要給大家介紹了關(guān)于vue中使用echarts并根據(jù)選擇條件動(dòng)態(tài)展示echarts圖表的相關(guān)資料,需要的朋友可以參考下
    2023-12-12
  • Vue如何使用Promise.all()方法并行執(zhí)行多個(gè)請(qǐng)求

    Vue如何使用Promise.all()方法并行執(zhí)行多個(gè)請(qǐng)求

    在Vue中,可以使用Promise.all()方法并行執(zhí)行多個(gè)異步請(qǐng)求,當(dāng)所有請(qǐng)求都成功返回時(shí),Promise.all()將返回一個(gè)包含所有請(qǐng)求結(jié)果的數(shù)組,如果其中任何一個(gè)請(qǐng)求失敗,則會(huì)觸發(fā)catch()方法并返回錯(cuò)誤信息,這種方式可以顯著提高程序的性能和響應(yīng)速度
    2025-01-01
  • vue-router懶加載速度緩慢問題及解決方法

    vue-router懶加載速度緩慢問題及解決方法

    這篇文章主要介紹了vue-router懶加載速度緩慢問題及解決方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-11-11

最新評(píng)論