当前位置:首页 > 科技  > 软件

JavaScript如何优雅地告别Cannot read properties of undefined,Optional类体验

来源: 责编: 时间:2024-05-16 09:10:08 200观看
导读相信很多开发者在开发中经常遇到的一个报错:Uncaught TypeError: Cannot read properties of undefined.图片作为一名熟练的前端攻城狮,你一眼就能这是由于读取一个对象属性时,对象为 undefined 时导致的。要想避免,我们

相信很多开发者在开发中经常遇到的一个报错:npi28资讯网——每日最新资讯28at.com

Uncaught TypeError: Cannot read properties of undefined.npi28资讯网——每日最新资讯28at.com

图片图片npi28资讯网——每日最新资讯28at.com

作为一名熟练的前端攻城狮,你一眼就能这是由于读取一个对象属性时,对象为 undefined 时导致的。npi28资讯网——每日最新资讯28at.com

要想避免,我们需要做下判断。npi28资讯网——每日最新资讯28at.com

let a = fetch(url, params);a?.result?.map(console.log);

或者你使用 try catch 结构来捕获异常。npi28资讯网——每日最新资讯28at.com

try {  let a = fetch(url, params);  a.result.map(console.log);} catch (err) {  console.log(err);}

当然,我们还有很多其他的选择,这里就不一一列举了。npi28资讯网——每日最新资讯28at.com

接下来我介绍一种我最新学到的方案——Java 的 Optional 类。npi28资讯网——每日最新资讯28at.com

Optional 类是 Java 中解决空指针异常(NullPointerException)的一种方案。(它和 Cannot read properties of undefined 是一样的错误),我们看看没有 Optional 类的情况。npi28资讯网——每日最新资讯28at.com

String str = null;// System.out.println(appendTest.toString());// 上面会触发:NullPointerException,下面是常见的应对方法if (str !== null) {    System.out.println(str.toString());} else {    System.out.println("str is null!!!");}

但是使用 Optional 就优雅的多了。npi28资讯网——每日最新资讯28at.com

String str = null;// 生成Optional类,ofNullablebiao 生成可以为null的对象Optional<String> optional = Optional.ofNullable(name);

生成 Optional 类还有 of 方法,不同的是不能为 null,否则调用 ifPresent 依然会报错 NullPointerException。npi28资讯网——每日最新资讯28at.com

ifPresent: 如果存在就打印它,否则不进行任何操作。npi28资讯网——每日最新资讯28at.com

optional.ifPresent(str -> System.out.println(str));// 等价于optional.ifPresent(System.out::println);

orElseGet:如果存在就返回它,否则执行后面的表达式。npi28资讯网——每日最新资讯28at.com

optional.orElseGet(() -> System.out.println("str is null!!"));

除此之外还有很多有意思的接口,比如我们熟悉的:map、flatmap、filter 等。npi28资讯网——每日最新资讯28at.com

需要注意的是,因为 Optional 是一个容器类,它的方法返回的仍然是 Optional 对象,所以你可以继续对返回的 Optional 对象进行链式调用。例如:npi28资讯网——每日最新资讯28at.com

import java.util.Optional;public class Person {    // something}public class Main {    public static void main(String[] args) {        // 创建一个可能为 null 的 Person 对象        Person person = new Person("John Doe", 30);        // 使用 Optional 对象进行链式调用        Optional<Person> optionalPerson = Optional.ofNullable(person)                .filter(p -> p.getAge() >= 18)                .map(p -> new Person(p.getName().toUpperCase(), p.getAge())                .flatMap(p -> Optional.of(new Person(p.getName(), p.getAge() + 1)));        // 输出结果        optionalPerson.ifPresent(p -> System.out.println("Name: " + p.getName() + ", Age: " + p.getAge()));    }}

更多信息可以看下面这张截图:npi28资讯网——每日最新资讯28at.com

图片图片npi28资讯网——每日最新资讯28at.com

这些方法像极了 javascript 的数组方法,但是他们的区别是,在 Java 中,Optional 类主要用于包装单个对象,以表示一个可能存在或可能不存在的值。它并不直接支持包装数组。npi28资讯网——每日最新资讯28at.com

让我们回到 javascript,这种方案似乎可以很好的解决前端的问题。好奇的搜索 GitHub,这种方案有很多 javascript 版本的实现。npi28资讯网——每日最新资讯28at.com

例如:https://github.com/JasonStorey/Optional.jsnpi28资讯网——每日最新资讯28at.com

const Optional = require("optional-js");// Define some simple operationsconst getUserId = (username) => (username === "root" ? 1234 : 0);const verify = (userId) => userId === 1234;const login = (userId) => console.log("Logging in as : " + userId);// Declare a potentially undefined valueconst username = process.argv[2];// Wrap username in an Optional, and build a pipeline using our operationsOptional.ofNullable(username).map(getUserId).filter(verify).ifPresent(login);

这看起来妙极了!!!npi28资讯网——每日最新资讯28at.com

那么这种方案是怎么实现的呢?关键是函数返回值依然是个 Optional 对象。下面我们简单的实现一下这个过程。npi28资讯网——每日最新资讯28at.com

class Optional {  constructor(value) {    this.value = value;  }  static of(value) {    return new Optional(value);  }  isPresent() {    return this.value !== undefined && this.value !== null;  }  map(mapper) {    if (this.isPresent()) {      const mappedValue = mapper(this.value);      return Optional.of(mappedValue);    }    return Optional.ofNullable(null);  }  flatMap(mapper) {    if (this.isPresent()) {      const mappedValue = mapper(this.value);      if (mappedValue instanceof Optional) {        return mappedValue;      }      return Optional.ofNullable(mappedValue);    }    return Optional.ofNullable(null);  }  orElse(defaultValue) {    return this.isPresent() ? this.value : defaultValue;  }  static ofNullable(value) {    return Optional.of(value);  }}function getNameLength(person) {  return Optional.ofNullable(person)    .map((p) => p.name)    .map((name) => name.length)    .orElse(0);}const person = { name: "John Doe" };console.log(getNameLength(person)); // 输出:8const emptyPerson = null;console.log(getNameLength(emptyPerson)); // 输出:0

你觉得这个方案可以吗?相信大家读到这里心中已经有答案了吧?npi28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-88388-0.htmlJavaScript如何优雅地告别Cannot read properties of undefined,Optional类体验

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 面试官:你的系统,是如何建模的?

下一篇: Java EE更名Jakarta EE对程序开发影响,你知道吗?

标签:
  • 热门焦点
  • 官方承诺:K60至尊版将会首批升级MIUI 15

    全新的MIUI 15今天也有了消息,在官宣了K60至尊版将会搭载天玑9200+处理器和独显芯片X7的同时,Redmi给出了官方承诺,K60至尊重大更新首批升级,会首批推送MIUI 15。也就是说虽然
  • Redmi Pad评测:红米充满野心的一次尝试

    从Note系列到K系列,从蓝牙耳机到笔记本电脑,红米不知不觉之间也已经形成了自己颇有竞争力的产品体系,在中端和次旗舰市场上甚至要比小米新机的表现来得更好,正所谓“大丈夫生居
  • 7月安卓手机性能榜:红魔8S Pro再夺榜首

    7月份的手机市场风平浪静,除了红魔和努比亚带来了两款搭载骁龙8Gen2领先版处理器的新机之外,别的也想不到有什么新品了,这也正常,通常6月7月都是手机厂商修整的时间,进入8月份之
  • 印度登月最关键一步!月船三号今晚进入环月轨道

    8月5日消息,据印度官方消息,月船三号将于北京时间今晚21时30分左右开始近月制动进入环月轨道。这是该探测器能够成功的最关键步骤之一,如果成功将开始围
  • Flowable工作流引擎的科普与实践

    一.引言当我们在日常工作和业务中需要进行各种审批流程时,可能会面临一系列技术和业务上的挑战。手动处理这些审批流程可能会导致开发成本的增加以及业务复杂度的上升。在这
  • 重估百度丨“晚熟”的百度云,能等到春天吗?

    &copy;自象限原创作者|程心排版|王喻可2016年7月13日,百度云计算战略发布会在北京举行,宣告着百度智能云的正式启程。彼时的会场座无虚席,甚至排队排到了门外,在场的所有人几乎都
  • 得物宠物生意「狂飙」,发力“它经济”

    作者|花花小萌主近日,得物宣布正式上线宠物鉴别,通过得物App内的&ldquo;在线鉴别&rdquo;,可找到鉴别宠物的选项。通过上传自家宠物的部位细节,就能收获拥有专业资质认证的得物鉴
  • 首发天玑9200+ iQOO Neo8系列发布首销售价2299元起

    2023年5月23日晚,iQOO Neo8系列正式发布。其中,Neo系列首款Pro之作——iQOO Neo8 Pro强悍登场,限时售价3099元起;价位段最强性能手机iQOO Neo8同期上市
  • SN570 NVMe SSD固态硬盘 价格与性能兼具

    SN570 NVMe SSD固态硬盘是西部数据发布的最新一代WD Blue系列的固态硬盘,不仅闪存技术更为精进,性能也得到了进一步的跃升。WD Blue SN570 NVMe SSD的包装外
Top