【问题标题】:Double for loop without mutating prop, VUE3没有变异道具的双 for 循环,VUE3
【发布时间】: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


    【解决方案1】:

    你可以使用map()方法,像这样:

    computed: {
    doubledValues() {
      return this.data.map(item => ({...item, options: item.options.map(obj => {
        return (obj.value != null) ? { ...obj, value: obj.value * 2 } : { ...obj }
      })})
      );
    }
    }
    

    【讨论】:

      【解决方案2】:

      只需复制对象/数组。会是这样的

      computed: {
        doubledValues() {
          return this.data.map((item) => {
            const resultItem = {...item};
            resultItem.options = item.options.map((option) => {
              const copyOption = {...option};
              if (copyOption.value !== null && copyOption.value !== 0) {
                copyOption.value *= 2;
              }
              return copyOption;
            });
            return resultItem;
          });
        }
      }
      

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 2015-07-19
        • 1970-01-01
        • 2023-03-22
        • 2013-03-21
        • 1970-01-01
        • 2023-03-29
        • 2021-12-30
        相关资源
        最近更新 更多