当前位置: 首页 > news >正文

教育网站开发用例图杭州做网站模板

教育网站开发用例图,杭州做网站模板,成都网站开发,个人备案网站做购物网站可以不链式判断运算符 ?. ?.运算符,直接在链式调用的时候判断,左侧的对象是否为null或undefined。如果是的,就不再往下运算,而是返回undefined。 链判断运算符?.有三种写法。 obj?.prop // 对象属性是否存在 obj?.[expr] // 同上…

链式判断运算符 ?.

?.运算符,直接在链式调用的时候判断,左侧的对象是否为null或undefined。如果是的,就不再往下运算,而是返回undefined。

链判断运算符?.有三种写法。

obj?.prop // 对象属性是否存在
obj?.[expr] // 同上
func?.(…args) // 函数或对象方法是否存在
下面是obj?.[expr]用法的一个例子。

let hex = "#C0FFEE".match(/#([A-Z]+)/i)?.[1];

上面例子中,字符串的match()方法,如果没有发现匹配会返回null,如果发现匹配会返回一个数组,?.运算符起到了判断作用。

下面是?.运算符常见形式,以及不使用该运算符时的等价形式。
a?.b
// 等同于
a == null ? undefined : a.ba?.[x]
// 等同于
a == null ? undefined : a[x]a?.b()
// 等同于
a == null ? undefined : a.b()a?.()
// 等同于
a == null ? undefined : a()

Null 判断运算符 ??

读取对象属性的时候,如果某个属性的值是null或undefined,有时候需要为它们指定默认值。常见做法是通过||运算符指定默认值。

第一种弊端 所有的false都会取默认值
const headerText = response.settings.headerText || 'Hello, world!';
const animationDuration = response.settings.animationDuration || 300;
const showSplashScreen = response.settings.showSplashScreen || true;

上面的三行代码都通过||运算符指定默认值,但是这样写是错的。开发者的原意是,只要属性的值为null或undefined,默认值就会生效,但是属性的值如果为空字符串或false或0,默认值也会生效。

只有为null or undefined才会取默认值
const headerText = response.settings.headerText ?? 'Hello, world!';
const animationDuration = response.settings.animationDuration ?? 300;
const showSplashScreen = response.settings.showSplashScreen ?? true;

上面代码中,默认值只有在左侧属性值为null或undefined时,才会生效。


这个运算符的一个目的,就是跟链判断运算符?.配合使用,为null或undefined的值设置默认值。

const animationDuration = response.settings?.animationDuration ?? 300;

上面代码中,如果response.settings是null或undefined,或者response.settings.animationDuration是null或undefined,就会返回默认值300。也就是说,这一行代码包括了两级属性的判断。

??本质上是逻辑运算,它与其他两个逻辑运算符&&和||有一个优先级问题,它们之间的优先级到底孰高孰低。优先级的不同,往往会导致逻辑运算的结果不同。

现在的规则是,如果多个逻辑运算符一起使用,必须用括号表明优先级,否则会报错。

(lhs && middle) ?? rhs;
lhs && (middle ?? rhs);(lhs ?? middle) && rhs;
lhs ?? (middle && rhs);(lhs || middle) ?? rhs;
lhs || (middle ?? rhs);(lhs ?? middle) || rhs;
lhs ?? (middle || rhs);

逻辑赋值运算符 ||=、&&=、??=

// 或赋值运算符
x ||= y
// 等同于
x || (x = y)// 与赋值运算符
x &&= y
// 等同于
x && (x = y)// Null 赋值运算符
x ??= y
// 等同于
x ?? (x = y)
// 老的写法
user.id = user.id || 1;// 新的写法
user.id ||= 1;
http://www.yayakq.cn/news/247197/

相关文章:

  • 泉州网站建设方案服务企业网站如何做优化
  • 网站制作公司怎么看上海建设工程检测网官网
  • 龙岗建设高端网站心理咨询 网站模版
  • 中国科协网站建设招标cmseasy去版权
  • 明星设计网站风格说明做啤酒纸箱包装的网站
  • WordPress站内链接设置音乐网站建设的意义
  • 大型科技网站app找什么公司
  • 网站开发 教材淘宝网站页面设计
  • 做橡胶应该看什么网站网站版面设计
  • 设计模板的软件青岛网站推广优化
  • 潍坊网站建设方案win7 iis建立网站
  • 招聘网站代理临海网站设计
  • 泰安网站建设公司哪家好兰州建设工程信息网站
  • 设计logo网站是平面设计不做网站和做app哪个难
  • 网站数据库如何建设做牛津布面料在哪个网站找客户
  • 教育网站制作软件桂林人论坛怎么注册
  • wordpress博客站搭建徐州网站制作方法
  • 网站建设一般多钱安阳网站建设哪里最好
  • 多网站建设快手自媒体平台注册入口
  • 做平台网站外包多少钱啊悦昂网站建设
  • 南通网站seo服务徐州房产信息网
  • 江西景德镇建设厅网站做网站需要的带宽上行还是下行
  • 龙口网站制作公司网站制作应该注意到的问题
  • 法治建设的网站咸阳建筑工程网
  • 上海商标注册什么是搜索引擎优化推广
  • 上海松江网站制作标识设计公司网站
  • 运城盐湖区姚孟信通网站开发中心如何做网站链接分析
  • 自助建网站代理专业小程序商城开发
  • opencms做网站 谁网络营销软件推广
  • 北京最新网站备案qq是哪个公司开发的软件