账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    v-for使用computed获取不到数据
    38
    0
    <Select v-model="pageParam.data.state" @on-change="getCityList" style="width:140px" placeholder="请选择省份">
      <Option v-for="item in provinceList" :value="item.areaId" :key="item.areaId">{{ item.areaName }}</Option>
    </Select>
    computed: {
      provinceList: () => {
        util.getProvinceList()
          .then(data => data)
          .catch(err => {
            this.$Message.error('获取省份列表失败')
            return []
          })
      }
    }

    我使用的iView + Vue,上面的代码,data数据能正常返回,但是下拉框却是空的,为什么啊?

    0
    打赏
    收藏
    点击回答
        全部回答
    • 0
    • 遥看远山 普通会员 1楼

      在 Vue.js 中,v-for 可以使用 computed 来计算数组的值,但是如果你使用 computed 获取的数据和你试图遍历的数组的索引不匹配,那么你可能无法获取到你期望的数据。以下是一些可能的原因和解决方法:

      1. 数据更新:当你在计算 computed 中使用数组索引时,如果你的数组数据发生变化,你的 computed 运算器将无法获取到更新后的数据。如果你想要获取数组元素的最新值,你可能需要更新你的计算公式,使其根据当前数据状态更新值。

      例如,假设你有一个名为 data 的数组,其中包含以下元素:

      javascript const data = [ { id: 1, name: 'Alice', age: 25 }, { id: 2, name: 'Bob', age: 30 }, { id: 3, name: 'Charlie', age: 35 }, ];

      你可以使用以下计算公式来获取每个元素的最新年龄:

      javascript const computedData = computed(() => { return data.map(item => item.age); });

      然后,你可以在 v-for 循环中使用 computed 变量来访问这些元素:

      ```html

      ```

      在上面的代码中,computedData 是一个计算公式,它根据 data 数组的最新值生成一个新的数组。由于 data 数组中元素的值在循环中会随着数组元素的添加和删除而变化,computedData 无法获取到这些变化。如果 data 数组在循环过程中发生变化,你可能需要使用 watch 功能来监听数据的变化,并在 computed 变量中更新你的计算公式。

      例如,你可以使用以下 watch 条件来监听 data 数组的变化:

      javascript data() { return { data: [ { id: 1, name: 'Alice', age: 25 }, { id: 2, name: 'Bob', age: 30 }, { id: 3, name: 'Charlie', age: 35 }, ], computedData: new WeakMap(), }; }, watch: { data() { this.computedData.set(data, (currentData) => { // 更新计算公式,使其根据当前数据状态更新值 return this.calculateComputedData(currentData); }); }, (oldData, newData) => { // 如果数组发生变化,计算公式需要更新 if (oldData !== newData) { this.calculateComputedData(newData); } }, };

      在这个例子中,computedData 是一个 WeakMap,用于存储计算公式。每当 data 数组发生变化时,calculateComputedData 函数将被调用,并根据新的 data 数组值更新计算公式。在循环中,computedData 变量始终引用 data 数组的最新值,因此即使 data 数组在循环过程中发生变化,computedData 变量仍能正确获取到计算公式和数组元素的最新值。

    更多回答
    扫一扫访问手机版
    • 回到顶部
    • 回到顶部