JavaScript

超轻量级php框架startmvc

vue v-for 使用问题整理小结

更新时间:2020-09-06 19:12:01 作者:startmvc
今天使用v-for指令的时候遇到一个错误[Vuewarn]:Errorinrender:"TypeError:Cannotreadproperty'children'ofundef

今天使用v-for指令的时候遇到一个错误

[Vue warn]: Error in render: "TypeError: Cannot read property 'children' of undefined"

页面使用代码


 <template v-for="(c,i) in modelList.Course.children">
 <div :key="i" class="course-block">
 <CourseStruct :process="isbuy" :course="c" />
 </div>
 </template>
<script>

export default {
 methods: {
 async getList(id) {
 const res = await GetChapterListByProductID(id);
 if (res.data) {
 this.modelList = res.data;
 }
 }
 }
}

</script>

报错原因:

  我猜测使用了嵌套属性的原因,在页面中无法解析出具体属性值,这个原因是我尝试出来的,但是不知道深层次的原因了,有知道的希望评论下。

解决方案:

  既然知道了原因,那么就好解决了,解决方法如下.


 <template v-for="(c,i) in cls">
 <div :key="i" class="course-block">
 <CourseStruct :process="isbuy" :course="c" />
 </div>
 </template>

 <script>

 export default {
 methods: {
     async getList(id) {
    const res = await GetChapterListByProductID(id);
    if (res.data) {
 this.modelList = res.data;
 var co = this.modelList.Course
 this.cls = co.children
   }
    }
      }
       }

      </script>

通过变量中转一下,放到另一个临时变量中,如果有嵌套引用属性的话,大家记得通过js操作放到一个临时变量中,不然就会报错哟。

总结

以上所述是小编给大家介绍的vue v-for 使用问题整理小结,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

vue v-for 使用 vue v-for