VUE中出现 Cannot read property ‘length‘ of undefined 的错误

问题描述:

Cannot read property ‘length’ of undefined @Override

在做项目时遇到了length的报错。不影响其他东西,只是看着很难受

在这里插入图片描述


原因分析:

因为后台在返回数据时是需要时间的,不管多快都是需要时间的但是在初始化时,并没有给一个空的数组,注意是数组形式,所以当调用 .length 方法时 这时后台数据还没有返回回来 此时它不是数组,就会报错!

解决方案:

可以在整体加一个 v-if
这样当数据还没有返回时 就不会渲染 只有数据返回回来时 才会进行渲染
这样就会解决报错的问题

<div class="main" v-if="book.items">
 <div class="img-list" 
   v-for="list in book.items.length > 5? book.items.slice(1, 4): book.items "
   v-bind:key="list.id">
   <div class="new-img">
     <img :src="imageUrl(list)" alt="">
     <h1 class="title">{{list.title}}</h1>
   </div>
 </div>

这样就解决啦!友情提示 报错时 看到Error in render 的问题 其实都是渲染问题噢
在这里插入图片描述

  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值