页面白屏了?看看可选链操作符(?.)
背景
今天又被 QA 找: 这个页面昨天还好好的页面, 今天就白屏了, 是不是你代码有问题啊, 赶紧看看。
上去一看,白屏 找到了原因:

原本 pickup,看看可选 dropoff 两个字段没有数据的话, 应该返回{},链操 结果现在pickup字段返回了null, 而我们取值的时候,也没对这个地方做防御。作符
list: openApiOrderInfo.pickup.address_list,页面结果就是:脚本报错, 页面不可用。白屏
解决起来也很简单,看看可选 要么给个默认值,链操 要么使用 ?作符. 做一层防御。
改完再试一下,页面 就 OK 了,白屏 页面恢复正常。看看可选
下面我们就说一下这个 ?链操.
今天的主要内容:
什么是可选链操作符(?.) 如何启用这个功能 可选链操作符(?.) 是如何工作的 Heny发布的相关些资料 总结正文语种
可选链操作符(?.), 大家都很熟悉了,作符这里再简单回顾一下。
什么是可选链操作符(?.)
可选链操作符(?.)允许读取位于连接对象链深处的属性的值,而不必明确验证链中的每个引用是否有效。网站模板
比如,思考一个存在嵌套结构的对象 obj。不使用可选链的话,查找一个深度嵌套的子属性时,需要验证之间的引用,例如:
let nestedProp = obj.first && obj.first.second;为了避免报错,在访问obj.first.second之前,要保证 obj.first 的值既不是 null,也不是 undefined。
如果只是直接访问 obj.first.second,而不对 obj.first 进行校验,则有可能抛出错误。
有了可选链操作符(?.),在访问 obj.first.second 之前,不再需要明确地校验 obj.first 的状态,再并用短路计算获取最终结果:
let nestedProp = obj.first?.second;这等价于以下表达式,但实际上没有创建临时变量:
let temp = obj.first; let nestedProp = ((temp === null || temp === undefined) ? undefined : temp.second);?. 操作符的功能类似于 . 链式操作符,不同之处在于:
在引用为空(nullish) (null 或者 undefined) 的情况下不会引起错误,该表达式短路返回值是: undefined。
与函数调用一起使用时,如果给定的b2b信息网函数不存在,则返回 undefined。
当尝试访问可能不存在的对象属性时,使用可选链操作符将会使表达式更短、更简明。
有两点需要我们留意:
如果存在一个属性名且不是函数, 使用 ?. 仍然会产生一个 TypeError 异常 (x.y is not a function).
let result = someInterface.customMethod?.();如果 someInterface 自身是 null 或者 undefined ,异常 TypeError 仍会被抛出。
如果你希望允许 someInterface 也为 null 或者 undefined,那么你需要像这样写 someInterface?.customMethod?.()
可选链不能用于赋值
let object = {}; object?.property = 1; // Uncaught SyntaxError: Invalid left-hand side in assignment如何启用这个功能
// install npm install --save-dev @babel/plugin-proposal-optional-chaining // babel config { "plugins": [ "@babel/plugin-proposal-optional-chaining" //可选链 "@babel/plugin-proposal-nullish-coalescing-operator", //双问号 ] }可选链操作符(?.) 是如何工作的
const a = { b: 1 }; console.log(a?.b);会被转换成:
const a = { b: 1 }; console.log(a === null ? void 0 : a.b); 
如果层级更深, 会创建临时变量用于记录:
const a = { b: { c: 1, d: 2, } }; console.log(a?.b?.c)会被转换成:
var _a$b; const a = { b: { c: 1, d: 2 } }; console.log( a === null || a === void 0 ? void 0 : (_a$b = a.b) === null || _a$b === void 0 ? void 0 : _a$b.c ); 
Heny发布的相关些资料
Heny 目前是 babel 项目的负责人,之前发过一片介绍当前 babel 困境的文章: 知名团开源项目存活有多难?被数百万人使用的 Babel 陷入财务困境

上图推文链接:https://twitter.com/left_pad/status/1136282005170262016
感兴趣的可以去看看。
总结
?. 使用起来是非常方便的, 但如果用的不好, 也会隐藏本应该暴露出来的问题。
所以, 使用的时候一定要清楚自己在做什么。
?. 还有个小兄弟叫 空值合并运算符(??), 这里就不说了, 去 MDN 看文档吧。
今天就这么多,免费信息发布网 希望对大家有所启发。
相关文章
电脑计算器输入数字错误的问题(探讨计算器输入数字错误的原因和解决方法)
摘要:电脑计算器作为人们日常生活和工作中的重要工具,经常被使用。然而,很多时候我们会遇到电脑计算器输入数字错误的情况。本文将从原因和解决方法两个方面进行探讨,帮助读者更好地解决这个问题。...2025-11-05
在日常使用pandas的过程中,由于我们所分析的数据表规模、格式上的差异,使得同样的函数或方法作用在不同数据上的效果存在差异。而pandas有着自己的一套「参数设置系统」,可以帮助我们在遇到不同的数据2025-11-05
本文转载自微信公众号「Java中文社群」,作者磊哥 。转载本文请联系Java中文社群公众号。 JDK 15 在 2020 年 9 月 15 号正式发布了,这次发布的主要功2025-11-05
JavaScript是一种属于网络的脚本语言,被广泛用于Web应用开发,常用来为网页添加各式各样的动态功能,为用户提供更流畅美观的浏览效果。那么如何学JavaScript?本篇文章就来给大家推荐一些学2025-11-05解决电脑关键事件错误的有效方法(保护您的电脑免受关键事件错误的影响)
摘要:在数字化时代,电脑已经成为人们生活和工作中不可或缺的工具。然而,我们常常会遇到一些关键事件错误,如系统崩溃、病毒感染、软件冲突等,这些错误给我们的使用带来了不便和困扰。为了保护您的...2025-11-05
前面程序喵介绍过C++11的新特性,这篇文章介绍下C++14的新特性。「函数返回值类型推导」C++14对函数返回类型推导规则做了优化,先看一段代码:#include<iostream>u2025-11-05


最新评论