- 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 条
- 全部回答
-
遥看远山 普通会员 1楼
在 Vue.js 中,
v-for可以使用 computed 来计算数组的值,但是如果你使用 computed 获取的数据和你试图遍历的数组的索引不匹配,那么你可能无法获取到你期望的数据。以下是一些可能的原因和解决方法:- 数据更新:当你在计算 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
- {{ item.name }} - {{ item.age }}
```
在上面的代码中,
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变量仍能正确获取到计算公式和数组元素的最新值。
- 扫一扫访问手机版
回答动态

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器更新之后。服务器里面有部分玩家要重新创建角色是怎么回事啊?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题函数计算不同地域的是不能用内网吧?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题ARMS可以创建多个应用嘛?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题在ARMS如何申请加入公测呀?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题前端小程序接入这个arms具体是如何接入监控的,这个init方法在哪里进行添加?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器刚到期,是不是就不能再导出存档了呢?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器的游戏版本不兼容 尝试更新怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器服务器升级以后 就链接不上了,怎么办?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器转移以后服务器进不去了,怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器修改参数后游戏进入不了,是什么情况?预计能赚取 0积分收益
- 回到顶部
- 回到顶部

