首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

嵌套结构取值如何编写兜底逻辑

嵌套结构取值如何编写兜底逻辑 github总基地:http://www.github.com/dashnowords/blogs 博客园地址:《大史住在大前端》原创博文目录 掘金地址:https...• 路径中有null或undefined时,即使有后续取值路径,也不会报错,而是返回默认值 • 最终结果为undefined或null时都返回默认值(和lodash.get的区别) • MDN关于可选链的描述.../plugin-proposal-nullish-coalescing-operator", "@babel/plugin-proposal-optional-chaining" ] } 代码中使用可选链...console.log(result5); // defaultValue console.log(result6); // defaultValue 方案3——利用函数式编程实现get方法 原文可见:如何优雅安全地深层数据结构取值..._a$b$c$d : "defaultValue"; 基本逻辑可以按括号内往外看,并不复杂,就是每次取属性都对undefined和null进行了容错处理。

2.9K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    JS 为啥 .map(parseInt) 返回

    JavaScript ,Truthy (真值)指的是 布尔值 上下文中转换后的值为真的值。...falsy(虚值)是 Boolean 上下文中已认定可转换为‘假‘的值。 JS的对象不是真值就是虚值。 令人困惑的是,这意味着字符串“false”,字符串“0”,空对象{}和空数组[]都是真的。...0 1 2 3 4 5 6 7 8 9 10 当我们0数到9时,每个数字(0-9)都有不同的符号,但是当我们数到10时,我们需要两个不同的符号(1和0)来表示这个数字。...不同的计数系统具有不同的基数,因此,相同的数字不同的计数系统可以表示不同的数字。...你可能已经注意到,我们的示例,当输入为11时,parseInt返回3,这对应于上表的二进制列。 函数参数 JS 函数调用,我们可以传入任意的参数,即使它们不等于声明时的函数参数的数量。

    4.7K30

    JS 的 (Weak)Set 和 (Weak)Map

    Map Map对象保存键值对。任何值(对象或者原始值) 都可以作为一个键或一个值。它和 JS 对象不同,JS 对象只能用字符串和Symbol作为键,而Map可以使用任何值。...虽然ES5开始可以用map = Object.create(null) 来创建一个没有原型的对象,但是这种用法不太常见。 Map涉及频繁增删键值对的场景下会有些性能优势。...=> undefined} Map是可以直接被迭代的,一个Map对象迭代时会根据对象中元素的插入顺序来进行 — 一个for...of循环每次迭代后会返回一个形式为[key,value]的数组。...delete(key) 移除Map对象中指定的元素,如果Map对象存在该元素,则移除它并返回 true;否则如果该元素不存在则返回false。 clear() 移除Map对象的所有元素。...Map[Symbol.species] 返回一个Map构造函数,一般用于创建派生对象。 Map.prototype 原型 WeakMap WeakSet对象允许你将弱保持对象存储一个集合

    2.1K20

    JS 如何使用 Ajax 来进行请求

    本教程,我们将学习如何使用 JS 进行AJAX调用。 1.AJAX 术语AJAX 表示 异步的 JavaScript 和 XML。 AJAX JS 中用于发出异步网络请求来获取资源。...2.XMLHttpRequest XMLHttpRequest对象(简称XHR)较早的时候用于服务器异步检索数据。 之所以使用XML,是因为它首先用于检索XML数据。...来自服务器的响应存储responseText变量,该变量使用JSON.parse()转换为JavaScript 对象。...如果存在网络错误,则将拒绝,这会在.catch()块处理。 如果来自服务器的响应带有任何状态码(如200、404、500),则promise将被解析。响应对象可以.then()块处理。...将响应代码(例如404、500)视为可以catch()块处理的错误,因此我们无需显式处理这些错误。

    8.9K20

    Node.js如何逐行读取文件

    Node.js如何逐行读取文件 本文翻译自How to read a file line by line in Node.js 能够逐行读取文件为我们提供了一个读取大型文件的机会,而无需将它们完全加载到内存...我们已经讨论了如何在Java逐行读取文件,让我们看一下Node.js逐行读取文件的方式。...FS模块 Node.js逐行读取文件的最简单方法是使用本地fs模块的fs.readFileSync()方法: const fs = require('fs'); try { // read...Readline模块 Readline是另一个Node.js本机模块,是专门为此目的开发的-任何readable stream中一次读取一行。 您甚至可以使用此模块从命令行读取输入数据。...您可以通过终端运行以下命令将其添加到项目中: $ npm i line-reader --save 如果使用的是yarn,可以通过终端运行以下命令将其添加到项目中: $ yarn add line-reader

    13.6K20

    jsmap遍历数组对象_js遍历数组

    forEach()和map()都是遍历数组的方法,用法类似,但是还是有很大区别: 相同点:       1.都是循环遍历数组的每一项;       2.遍历执行匿名函数都可以接收三个参数,分别为...arr.forEach(function(i,index,arr){ sum += i; console.log("sum的值为:",sum); }) //执行5次,最终结果 10 ** js... map 遍历数组 ** map 方法会迭代数组的每一个元素,并根据回调函数来处理每一个元素,最后返回一个新数组。...我们的例子,回调函数只有一个参数,即数组中元素的值 (val 参数) ,但其实,你的回调函数也可以支持多个参数,譬如:元素的索引index、原始数组arr。...例子:使用 map 方法来为 oldArray 的每一项增加3,并且 newArray 中保存它们。 oldArray 不应该被改变。

    19.6K30

    Vue 如何插槽中发出数据

    我们知道使用作用域插槽可以将数据传递到插槽,但是如何插槽传回来呢? 将一个方法传递到我们的插槽,然后插槽调用该方法。 我信无法发出事件,因为插槽与父组件共享相同的上下文(或作用域)。...,我们将介绍其工作原理,以及: 插槽到父级的 emit 当一个槽与父组件共享作用域时意味着什么 插槽到祖父组件的 emit 更深入地了解如何使用方法插槽通讯回来 插槽到父级的 emit 现在看一下...因此,无论该按钮模板位于何处,都可以访问handleClick方法。 乍一看,这可能有点奇怪,这也是为什么插槽很难理解的原因之一。...插槽发回子组件 与Child 组件通讯又如何呢?...我们知道如何将数据从子节点传递到槽 // Child.vue 以及如何在作用域内的插槽中使用它

    3K20

    怀英漫谈4-JSMap

    一开始并没有搜到JSMap的用法,所以才采用了双重循环的逻辑。11月份刚开始做这个功能的时候,是有在网上查过JSMap用法的,网上的大多解决方案是用循环去模拟Map。...理由是JS并没有Map这个数据结构。后来去W3C上查,也确实没有,外加之当时对JS对象的理解并不深,所以最终用双重循环先实现了功能。 不过搜寻的过程中产生了一个疑惑。...如果Map这种数据结构Java能得到广泛地运用,那就说明它是有相当使用场景的,既然如此,那么JS为什么就没有Map这种数据结构呢?...这种写法是我查找如何遍历JS对象的属性值的时候偶然间发现的。这种做法将Map的数据结构和对象相互独立的关系变为了从属关系,Map是对象的子集,是它的一种表现方式。...今天和你聊了聊我对JS对象的,一个新角度的理解,希望能对你有所帮助。 清 单 JSMap即对象,对象即Map

    1.4K60

    Bash如何字符串删除固定的前缀后缀

    更多好文请关注↑ 问: 我想从字符串删除前缀/后缀。例如,给定: string="hello-world" prefix="hell" suffix="ld" 如何获得以下结果?...如果模式与 parameter 扩展后的值的开始部分匹配,则扩展的结果是 parameter 扩展后的值删除最短匹配模式(一个 # 的情况)或最长匹配模式(## 的情况)的值 ${parameter...如果模式与 parameter 扩展后的值的末尾部分匹配,则扩展的结果是 parameter 扩展后的值删除最短匹配模式(一个 % 的情况)或最长匹配模式(%% 的情况)的值。.../bash/manual/bash.html#Shell-Parameter-Expansion 相关阅读: bash:-(冒号破折号)的用法 Bash如何将字符串转换为小写 shell编程...$(cmd) 和 `cmd` 之间有什么区别 如何Bash变量删除空白字符 更多好文请关注↓

    45510

    jsset和map的区别_list和set

    Map和Object的区别: 一个Object 的键只能是字符串或者 Symbols,但一个Map 的键可以是任意值。 Map的键值是有序的(FIFO 原则),而添加到对象的键则不是。...Map的键值对个数可以 size 属性获取,而 Object 的键值对个数只能手动计算。 Object 都有自己的原型,原型链上的键名有可能和你自己在对象上的设置的键名产生冲突。...): 判断Map对象是否有Key所对应的值,有返回true,否则返回false delete(key): 通过键值Map移除对应的数据 clear(): 将这个Map的所有元素删除 const...有几个特殊值需要特殊对待: +0 与 -0 存储判断唯一性的时候是恒等的,所以不重复 undefined 与 undefined 是恒等的,所以不重复 NaN 与 NaN 是不恒等的,但是 Set...b.has(x))) // {1} 综上所述,主要有一下几个区别: 1.Map是键值对,Set是值的集合,当然键和值可以是任何的值; 2.Map可以通过get方法获取值,而set不能因为它只有值; 3

    3.1K20

    如何使用 TSX Node.js 本地运行 TypeScript

    但我们可以Node.js中直接运行TypeScript文件而无需任何编译步骤,这称为加载器(Loaders)。...您可以官方文档中了解有关此功能的更多信息,包括使用转换示例。TSXTSX是我们的ts-node的最新和最改进版本,它使用ESBuild快速将TS文件转译为JS。...最有趣的部分是,TSX被开发为Node的完整替代品,因此您实际上可以将TSX用作TypeScript REPL,只需使用npm i -g tsx全局安装它,终端运行tsx,然后就可以原生地编写TSX...扩展功能自Node 20.6版本以来,我们可以直接加载.env文件存在的环境配置文件。但如何同时使用加载器和配置文件呢?...重要提示:直接磁盘加载TS文件并使用加载器进行编译比先进行转译然后直接传递JavaScript文件要慢得多,因此建议仅在开发环境执行此操作。

    2.1K10
    领券