【发布时间】:2021-04-26 11:14:48
【问题描述】:
我有一个“数据”道具,看起来像这样:
data = [
{
"label":"gender",
"options":[
{"text":"m","value":0},
{"text":"f","value":1},
{"text":"x", "value":null}
]
},
{
"label":"age",
"options":[
{"text":"<30", "value":0},
{"text":"<50","value":1},
{"text":">50","value":3}
]
}
]
在一个计算属性中,我想要一个看起来与 data 属性完全一样的新数组,不同之处在于 - 举个例子来说 - 我想将 options 数组中的值乘以 2。简单来说js我之前也是这么干的,像这样:
data.forEach(item => {
item.options.forEach(option => {
if (option.value !== null && option.value !== 0) {
option.value *= 2;
}
})
});
现在我尝试在计算属性中使用 .map() 执行此操作,因此它不会改变我的数据道具,但我不知道如何。
computed: {
doubledValues() {
var array = this.data.map((item) => {
//...
item.options.map((option) => {
//... option.value * 2;
});
});
return array;
}
}
【问题讨论】:
标签: javascript vue.js map-function vue-props