当前位置: 首页 > 知识库问答 >
问题:

可能忽略无法读取未定义的属性'0'?[重复]

庄飞
2023-03-14

我正在创建一个个人脚本,在某些情况下会出现错误:

Cannot read property '0' of undefined

我有类似的东西

item["OfferSummary"][0]["LowestUsedPrice"][0]["FormattedPrice"]

是否可以完全忽略/覆盖此错误,使其仅打印n/a或--在该场景中?

共有3个答案

魏明亮
2023-03-14

即使您可以使用try-and-catch,我也不会这样做,我更愿意避免错误,因此您只需要检查您正在阅读的对象:

if(item && item["OfferSummary"].length && item["OfferSummary"][0]["LowestUsedPrice"].length) {
   //then do whatever
}

如果您知道项目总是定义的,那么可以避免在if中检查它。

邓嘉致
2023-03-14

您可以使用样板函数这样做:

function get(obj, property) {      
  if (Array.isArray(property)) {
    var current = obj;
    for (var i = 0, l = property.length; i < l; ++i) {
      if (Object(current) === current) current = current[property[i]];
      else {
        current = undefined;
        break;
      }
    }
    return current;
  }
  if (Object(obj) === obj) return obj[property];
}

字符串或数组传递给get以查找属性——如果未找到,将返回undefined

例子:

get(window, ['location', 'href']); // "http://stackoverflow.com..."
get(Number, 'MAX_VALUE'); // 1.7976931348623157e+308
汝才良
2023-03-14

您可以使用trycat来执行错误处理。

 类似资料:
  • 我正在用onsenui和react列清单。但我不能从onchanged调用绑定。 我不明白。。。。有人能解决这个问题吗? 这是我的密码。我想从输入项调用handlechanged方法。但是,无法读取未定义的属性“bind”被引发。

  • 为什么我得到这个错误不能读取未定义的触摸属性? 为什么它不能读取,但它可以读取 当我们使用

  • 问题内容: 我正在制作非常简单的react应用。但是,当我尝试通过onChange事件调用父(实际上是祖父母)组件的方法时,我一直在获取。 这是触发事件的组件/表单(因此,在绑定的父组件上调用方法…是的,因为我通过道具将其从父组件传递下来,所以在方法上使用了.bound(this)。) 这是我如何通过大多数父(祖父母)组件中的props传递该方法的方法。 这是我作为父项(方法所有者和方法调用程序之

  • 我正在测试发送电子邮件与流星js和nodemailer插件: 流星添加捷运:流星NodeEmailer 当页面加载时,我在导航器的控制台上看到错误:无法读取未定义的属性“创建运输”。 那么问题是什么呢? 代码如下: /////////////////////////////////////////// ///////////////

  • 我知道这方面还有很多类似的问题,但没有一个答案是有效的。在我的例子中,我有下面的代码,我正在尝试按分数降序排列记录数组。 最后一个函数是什么给我的问题.如果用户运行以下: var web=[{url:“www.southanpton.ac.uk”,内容:“南安普敦大学提供学位课程和世界一流的研究测试。”,{url:“www.xyz.ac.uk”,内容:“另一种大学考试”},{url:“www”,内

  • 我一直试图让firebase与react一起工作,但出现了此错误 未经处理的拒绝(TypeError):无法读取未定义的fetch D:/Peti/Programming/node/coursewebpage/src/components/coursePage.js:12 9 | const db=firebase.firestore()10 | const myAuthLevel=(fireba