vue中出现错误(“TypeError: Cannot read property ‘substring‘ of undefined“)

在Vue项目中,尝试动态渲染并使用substring截取字符串时遇到'TypeError: Cannot read property 'substring' of undefined'错误。问题源于未对数据源进行空值检查。为解决这个问题,可以在数据绑定前使用v-if指令进行判断,确保数据存在后再执行substring操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

vue项目中,动态渲染数据时,截取(substring())字符串中的一段字符,出现错误(“TypeError: Cannot read property ‘substring’ of undefined”)

目的:截取 "2019-10-15T07:20:47.000Z"中的 2019-10-15,在文章中渲染

方法:利用字符串 substring()函数进行截取

  • 函数:substring()
  • 定义:substring(start,end)表示从start到end之间的字符串,包括start位置的字符但是不包括end位置的字符。
  • 功能:字符串截取,比如想从"getUserDetails"中得到"getUser"就要用到substring(0,7)
    如下:
<div class="time">{{current.create_date.substring(0,10)}}</div>
*控制台打印输出:*
console.log(this.current.create_date);    // 2019-10-15T07:20:47.000Z
console.log(this.current.create_date.substring(0,10));  //2019-10-15

虽说截取成功,但是出现了错误:"TypeError: Cannot read property ‘substring’ of undefined"
错误展示

  • 报错内容:“Cannot read property ‘substring’ of undefined”
  • 报错原因:你没有判断数据来源是否为空。对字符串做substring时,没有判断其是否为空。
  • 解决方式:在数据前面的标签里面 进行判断 v-if=“字符串内容”
<div class="time">{{current.create_date.substring(0,10)}}</div>
报错:Cannot read property 'substring' of undefined"
修改:
<div class="time" v-if="current.create_date">{{current.create_date.substring(0,10)}}</div>
TypeError: Cannot read property 'call' of undefined错误是指在调用一个未定义的对象的call方法时发生的错误。根据引用和引用[2]的内容,我们可以了解到这个错误通常发生在使用Vue.js路由时,可能是因为路由配置有误导致调用了未定义的函数或方法。 根据引用中提到的错误详情,TypeError通常是由于变量或参数不是预期类型引起的。在Vue.js中,路由配置常常使用到call方法来调用相应的函数,而当调用的对象是undefined时,就会触发该错误。 举个例子,假设在Vue.js路由配置中有如下代码: ```javascript router.beforeEach((to, from, next) => { // 在此处调用了一个不存在的函数 to.meta.beforeEnter.call(); next(); }); ``` 在这个例子中,to.meta.beforeEnter是一个函数对象,但如果这个函数对象未定义,就会产生TypeError: Cannot read property 'call' of undefined错误。 因此,解决这个错误的方法就是确保在路由配置中所调用的函数或方法都是已定义的。可以检查路由配置文件,确保所有使用到call方法的函数都是存在的。另外,也可以在调用函数之前先进行类型判断,避免调用未定义的函数。 总结起来,TypeError: Cannot read property 'call' of undefined错误通常发生在Vue.js路由配置中,是由于调用了未定义的函数或方法导致的。解决这个错误的方法是确保所有调用的函数都是已定义的,并进行必要的类型判断。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值