vue 开发中遇到一个问题:当获取接口数据后,给一个空数组赋值接口的对象数组后,html 部分的 v-for 不能渲染这个对象数组,尝试过使用 this.$set 和 this.$forceUpdate 等方法都不能解决问题。
<ul>
<li v-for="item in list" :key="item.id">
{{item.title}} <!--v-for 不能渲染-->
</li>
</ul>
如上代码:list 本身已经有数据,但是 v-for 的标签无论如何也不被渲染。
<ul v-if="list.length > 0">
<li v-for="item in list" :key="item.id">
{{item.title}}
</li>
</ul>
一个很简单的解决办法是在 <ul> 标签加上 v-if=“list.length > 0”。 vue 的 diff 算法会监测数组变化,响应式地渲染列表。
在Vue开发过程中遇到一个难题,当从接口获取数据并赋值给一个空数组后,v-for指令无法渲染该对象数组。尝试使用this.$set和this.$forceUpdate等方法无效。问题的解决方法是在ul标签上添加v-if='list.length > 0',通过Vue的diff算法监听数组变化,实现列表的响应式渲染。

1216

被折叠的 条评论
为什么被折叠?



