zoukankan      html  css  js  c++  java
  • 巩固一下 JS 可选 (?.)操作符号,原来函数也可以用可选写法,又学到了!

    有梦想,有干货,微信搜索 【大迁世界】 关注这个在凌晨还在刷碗的刷碗智。

    本文 GitHub https://github.com/qq449245884/xiaozhi 已收录,有一线大厂面试完整考点、资料以及我的系列文章。

    可选的链接?.操作符用于使用隐式空检查访问嵌套对象属性。

    概述

    如何使用null (nullundefined)检查访问对象的嵌套属性?假设我们必须从后台的接口访问用户详细信息。

    可以使用嵌套的三元运算符 :

    const userName = response ? (response.data ? (response.data.user ? response.data.user.name : null) : null) : null;

    或者使用 if 进行空值检查:

    let userName = null;
    if(response && response.data && response.data.user){
      userName = response.data.user.name;
    }

    或者更好的方法是使它成为一个单行链接的&&条件,像这样:

    const userName = response && response.data && response.data.user && response.data.user.name;
    

    上述代码的共同之处在于,链接有时会非常冗长,并且变得更难格式化和阅读。这就是 ?.操作符被提出来的原因,我们改下 ?. 重构上面的代码:

    const userName = response?.data?.user?.name;

    很 nice 呀。

    语法

    ?. 语法在ES2020 中被引入,用法如下:

    obj.val?.pro  // 如果`val`存在,则返回`obj.val.prop`,否则返回 `undefined`。
    
    obj.func?.(args) // 如果 obj.func 存在,则返回 `obj.func?.(args)`,否则返回 `undefined`。
    
    obj.arr?.[index] // 如果 obj.arr 存在,则返回 `obj.arr?.[index]`,否则返回 `undefined`。
    

    使用?.操作符

    假设我们有一个 user 对象:

    const user = {
      name: "前端小智",
      age: 21,
      homeaddress: {
        country: "中国"
      },
      hobbies: [{name: "敲代码"}, {name: "洗碗"}],
      getFirstName: function(){
        return this.name;
      }
    }

    属性

    访问存在的属性:

    console.log(user.homeaddress.country); 
    // 中国

    访问不存在的属性:

    console.log(user.officeaddress.country); 
    // throws error "Uncaught TypeError: Cannot read property 'country' of undefined"

    改用 ?. 访问不存在的属性:

    console.log(user.officeaddress?.country); 
    // undefined

    方法

    访问存在的方法:

    console.log(user.getFirstName()); 
    // 前端小智

    访问不存在的方法:

    console.log(user.getLastName()); 
    // throws error "Uncaught TypeError: user.getLastName is not a function";

    改用 ?. 访问不存在的方法:

    console.log(user.getLastName?.()); 
    // "undefined"

    数组

    访问存在的数组:

    console.log(user.hobbies[0].name); 
    // "敲代码"

    访问不存在的方法:

    console.log(user.hobbies[3].name); 
    // throws error "Uncaught TypeError: Cannot read property 'name' of undefined"

    改用 ?. 访问不存在的数组:

    console.log(user.dislikes?.[0]?.name); 
    // "undefined"

    ?? 操作符

    我们知道 ?. 操作符号如果对象不存在,刚返回 undefined,开发中可能不返回 undefined 而是返回一个默认值,这时我们可以使用双问题 ?? 操作符。

    有点抽象,直接来一个例子:

    const country = user.officeaddress?.country;
    console.log(country);
    // undefined

    需要返回默认值:

    const country = user.officeaddress?.country ?? "中国";
    console.log(country);
    // 中国

    ~完,我是刷碗智,SPA走起来,下期见!


    代码部署后可能存在的BUG没法实时知道,事后为了解决这些BUG,花了大量的时间进行log 调试,这边顺便给大家推荐一个好用的BUG监控工具 Fundebug

    漫思
  • 相关阅读:
    twemproxy配置
    tomcat远程调试
    hadoop配置
    kafka原理分析
    hive-sql
    P1983 车站分级
    拓扑排序
    洛谷P1982 小朋友的数字
    字典树Trie
    城市交通费
  • 原文地址:https://www.cnblogs.com/sexintercourse/p/14883761.html
Copyright © 2011-2022 走看看