摘要:接下来先介绍七个马上就能用起来的小技巧。老实讲,文章所说的小技巧大部分都是新增的语法特性,,或者说已经发布好些年头,这些特性大家可能已经非常熟识。,对象合并,不多说,大部分场景可以取代。
作者:@davidwalshblog原文:7 Useful JavaScript Tricks
和许多其他语言一样,JavaScript 也需要靠很多小技巧去完成各种不同的事情。有的可能早已经广为人知,有的却可能会让你感到有些迷惑。接下来先介绍七个马上就能用起来的 JavaScript 小技巧。
数组去重完成数组去重可能比你想象中更容易:
var j = [...new Set([1, 2, 3, 3])] >> [1, 2, 3]
这里使用到了 Set 和扩展运算符。
数组和布尔关于如何过滤掉数组中的假值,有这样一个简单的技巧:
myArray .map(item => { // ... }) // Get rid of bad values .filter(Boolean);
只需要将 Boolean 传给 filter 函数即可过滤掉数组中的所有假值。
创建一个空对象你可能会直接使用对象字面量 {} 去创建一个空对象,但是这个空对象仍然包含 __proto__ 和 hasOwnProperty 以及其他的对象方法。这里提供一种方式,可以创建真正的空对象:
let dict = Object.create(null); // dict.__proto__ === "undefined" // No object properties exist until you add them
这个对象不包含任何属性或者方法。
对象合并在 JavaScript 中合并对象的需求应该有很多,比如当创建一个有很多选项的类或组件的时候。
const person = { name: "David Walsh", gender: "Male" }; const tools = { computer: "Mac", editor: "Atom" }; const attributes = { handsomeness: "Extreme", hair: "Brown", eyes: "Blue" }; const summary = {...person, ...tools, ...attributes}; /* Object { "computer": "Mac", "editor": "Atom", "eyes": "Blue", "gender": "Male", "hair": "Brown", "handsomeness": "Extreme", "name": "David Walsh", } */
扩展运算符(...) 让这项工作变得异常简单。
函数必需参数可以给函数设置默认参数是一项很厉害的特性,可以通过传一个函数去检查必需参数是否传参:
const isRequired = () => { throw new Error("param is required"); }; const hello = (name = isRequired()) => { console.log(`hello ${name}`) }; // This will throw an error because no name is provided hello(); // This will also throw an error hello(undefined); // These are good! hello(null); hello("David");解构赋值别名
解构是一项非常强大的特性,但有时我们期望用其他名称来引用这些属性,这时可以利用使用别名的技巧:
const obj = { x: 1 }; // Grabs obj.x as { x } const { x } = obj; // Grabs obj.x as { otherName } const { x: otherName } = obj;
需要避免跟已有变量产生命名冲突时非常有用。
获取 query 参数曾经我们必需通过正则表达式的方式去获取 query 参数的值,但现在已经不需要了,可以使用 URLSearchParams Web API:
// Assuming "?post=1234&action=edit" var urlParams = new URLSearchParams(window.location.search); console.log(urlParams.has("post")); // true console.log(urlParams.get("action")); // "edit" console.log(urlParams.getAll("action")); // ["edit"] console.log(urlParams.toString()); // "?post=1234&action=edit" console.log(urlParams.append("active", "1")); // "?post=1234&action=edit&active=1"后
译者说
似乎许多人仍然颇为沉迷于这种技巧性质的东西,如最前所言,大部分或许早已成为一些常识性的东西,但对于某个特定的个体而言,可能还是初次见面,多多指教的情况。老实讲,文章所说的小技巧大部分都是 ES6 新增的语法特性,ES6,或者说 ES2015 已经发布好些年头,这些特性大家可能已经非常熟识。而现在 ES 的发布方式,每年小版本更新,已经渐渐淡化版本的概念,更关心的或许是宿主环境实现了什么。
逐条细说,第一条,是流传相当广的一行代码。2,Boolean 本身也是一个构造函数,不使用 new 的时候相当于进行一个 ToBoolean 转换操作,但这条平常好像也没有场景用到。3,使用对象字面量 {} 相当于是 Object.create(Object.prototype) ,如果不希望有太多对象方法,倒是可以试试 Object.create(null)。4,对象合并,不多说,大部分场景可以取代 Object.assign 。5,对函数参数默认值挺有意思的一种用法。6,解构赋值别名,没什么好说的。7,URLSearchParams 这是一个新的浏览器的 API ,不算 JavaScript 语言的,第一次见,支持度还比较弱。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/104073.html
摘要:操作的层级在设计按钮的时候必须明显的体现出来首要操作必须明显高对比度的背景颜色适用于这里。只有当销毁操作是当前首要操作的时候采用高对比度的红色背景样式,比如弹出对话框的确认取消按钮。 在微博看到别人转发的这篇文章,里面的每一点都觉得非常实用,就决定翻译一下,也算是给自己存个档,加深一下印象。毕竟作为一个前端页面仔,页面UI的美化也是我们的工作,而且还会经常会被要求在页面上加个这个或者加...
摘要:每种编程语言都有一些黑魔法或者说小技巧,也不例外,大部分是借助或者浏览器新特性实现。下面介绍的个实用小技巧,相信其中有些你一定用过。当然不管语言如何变化,我们总能在编程中总结一些小技巧来精简代码。 showImg(https://segmentfault.com/img/remote/1460000018902642); 每种编程语言都有一些黑魔法或者说小技巧,JS也不例外,大部分是借...
阅读 1317·2023-04-25 16:45
阅读 1874·2021-11-17 09:33
阅读 2259·2021-09-27 14:04
阅读 889·2019-08-30 15:44
阅读 2572·2019-08-30 14:24
阅读 3366·2019-08-30 13:59
阅读 1620·2019-08-29 17:00
阅读 857·2019-08-29 15:33