10实用的JS实用技巧
1. 删除数组尾部元素
一个简单方法就是改变数组的length
值:
const arr = [11, 22, 33, 44, 55, 66];// truncantingarr.length = 3;console.log(arr); //=> [11, 22, 33]// clearingarr.length = 0;console.log(arr); //=> []console.log(arr[2]); //=> undefined
2. 使用对象解构(object destructuring)来模拟命名参数
如果需要将一系列可选项作为参数传入函数,你很可能会使用对象(Object)来定义配置(Config)。
doSomething({ foo: 'Hello', bar: 'Hey!', baz: 42 });function doSomething(config) { const foo = config.foo !== undefined ? config.foo : 'Hi'; const bar = config.bar !== undefined ? config.bar : 'Yo!'; const baz = config.baz !== undefined ? config.baz : 13; // ...}
不过这是一个比较老的方法了,它模拟了 JavaScript 中的命名参数。
在 ES 2015 中,你可以直接使用对象解构:
function doSomething({ foo = 'Hi', bar = 'Yo!', baz = 13 }) { // ...}
让参数可选也很简单:
function doSomething({ foo = 'Hi', bar = 'Yo!', baz = 13 } = {}) { // ...}
3. 使用对象解构来处理数组
可以使用对象解构的语法来获取数组的元素:
const csvFileLine = '1997,John Doe,US,john@doe.com,New York';const { 2: country, 4: state } = csvFileLine.split(',');
4. 在 Switch 语句中使用范围值
可以这样写满足范围值的语句:
function getWaterState(tempInCelsius) { let state; switch (true) { case (tempInCelsius <= 0): state = 'Solid'; break; case (tempInCelsius > 0 && tempInCelsius < 100): state = 'Liquid'; break; default: state = 'Gas'; } return state;}
5. await 多个 async 函数
在使用 async/await 的时候,可以使用 Promise.all 来 await 多个 async 函数
await Promise.all([anAsyncCall(), thisIsAlsoAsync(), oneMore()])
6. 创建 pure objects
你可以创建一个 100% pure object,它不从Object
中继承任何属性或则方法(比如constructor
, toString()
等)
const pureObject = Object.create(null);console.log(pureObject); //=> {}console.log(pureObject.constructor); //=> undefinedconsole.log(pureObject.toString); //=> undefinedconsole.log(pureObject.hasOwnProperty); //=> undefined
7. 格式化 JSON 代码
JSON.stringify
除了可以将一个对象字符化,还可以格式化输出 JSON 对象
const obj = { foo: { bar: [11, 22, 33, 44], baz: { bing: true, boom: 'Hello' } } };// The third parameter is the number of spaces used to// beautify the JSON output.JSON.stringify(obj, null, 4); // =>"{// => "foo": {// => "bar": [// => 11,// => 22,// => 33,// => 44// => ],// => "baz": {// => "bing": true,// => "boom": "Hello"// => }// => }// =>}"
8. 从数组中移除重复元素
通过使用集合语法和 Spread 操作,可以很容易将重复的元素移除:
const removeDuplicateItems = arr => [...new Set(arr)];removeDuplicateItems([42, 'foo', 42, 'foo', true, true]);//=> [42, "foo", true]
9. 平铺多维数组
使用 Spread 操作平铺嵌套多维数组:
const arr = [11, [22, 33], [44, 55], 66];const flatArr = [].concat(...arr); //=> [11, 22, 33, 44, 55, 66]
不过上面的方法仅适用于二维数组,但是通过递归,就可以平铺任意维度的嵌套数组了:
function flattenArray(arr) { const flattened = [].concat(...arr); return flattened.some(item => Array.isArray(item)) ? flattenArray(flattened) : flattened;}const arr = [11, [22, 33], [44, [55, 66, [77, [88]], 99]]];const flatArr = flattenArray(arr); //=> [11, 22, 33, 44, 55, 66, 77, 88, 99]
希望这些小技巧能帮助你写好 JavaScript ~
10实用的JS实用技巧相关推荐
- 2个实用的JS小技巧
如何优雅的捕获错误 之前的经常会出现这样的代码逻辑: // 假设这是一个API接口调用 function userInfo () {return new Promise((resolve, rejec ...
- 快过年了,分享 25 个 JS 实用技巧送给大家吧
本文主要介绍一些JS中用到的小技巧,可以在日常Coding中提升幸福度,将不定期更新~ 类型强制转换 1.1 string强制转换为数字 可以用 *1来转化为数字(实际上是调用 .valueOf方法) ...
- 这10个实用的Javascript调试技巧,你知道吗?
见过太多同学调试Javascript只会用简单的console.log甚至alert,看着真为他们着急.因为大多数同学追求优雅而高效地写代码,却忽略了如何优雅而高效地调试代码,不得不说是有点" ...
- 助你掌握搜索神器,10个实用的Elasticsearch查询技巧
前言 Elasticsearch是一个非常流行的搜索引擎,已经成为了许多企业的首选解决方案.然而,我们要想成为一个优秀的程序员,就必须掌握各种查询技巧.本文将向大家介绍10个实用的Elastics ...
- Mac电脑高手都会用的10个Mac OS实用技巧,都是干货值得收藏!
Mac OS中其实有很多隐藏实用的功能,但是因为各种各样的原因,它们没能进入用户的视线.工欲善其事,必先利其器.好的工具可以提高生产效率,熟练的使用各种技巧可以事半功倍.今天,小编给大家带来了10个你 ...
- 办公技巧:分享12个实用的word小技巧,欢迎收藏!
今天给大家分享12个实用的word小技巧,希望对大家能有所帮助! 1. Word表格自动填充序号 在Word表格里选中要填入相同内容的单元格,单击"格式→项目符号和编号",进入&q ...
- 前端:分享一些实用的JS代码片段
今天给大家分享一些实用的JS代码片段,有需要的朋友欢迎收藏! 1.获取浏览器的版本 function getBrowser() {var UserAgent = navigator.userAgent ...
- 继续分享 5 个实用的 vs 调试技巧
前言 我在上一篇文章????<5 个非常实用的 vs 调试技巧> 中分享了 5 个我认为非常值得了解的 vs 调试技巧,本周继续分享 5 个很基础但同样实用的调试技巧. 1. 条件断点 作 ...
- 计算机办公软件的使用技巧,实用的Word小技巧集锦(1)办公软件知识 -电脑资料
一,把文字替换成图片 首先把图片复制到 剪贴板中,然后打开替换对话框,在"查找内容"框中输入将被替换的文字,接着在"替换为"框中输入"^c" ...
最新文章
- 学习JS面向对象成果,借国庆发布个最新作品与大家交流
- JAVA Thread线程异常监控
- Spring MVC普通类或工具类中调用service报空空指针的解决办法(调用service报java.lang.NullPointerException)...
- Redis实战(二):Redis 的 String 类型 bitmap
- (转)解读NTFS(一)
- python:第一个简单爬虫程序
- django 1.8 官方文档翻译: 2-5-10 数据库函数
- 推荐学习网页标准的20个好去处
- 深入解析Mysql 主从同步延迟原理及解决方案
- RTX2009管理器服务运行状态空白
- Python编程——实现屏幕广告语的滚动
- logrotate 管理日志文件不生效
- Android 中app加固与瘦身
- 时间晶体,一种曾被认为是无法存在的物质,被创造出来了吗?
- 初识机器阅读理解(Machine Reading Comprehension)
- HDU-6578 Blank
- phpmyadmin mysql管理器_phpMyAdmin(MySQL的资料库管理工具)
- 微信“戒烟”了!网友:我也戒
- 【Excel统计分析插件】上海道宁为您提供统计分析、数据可视化和建模软件——Analyse-it
- 数据结构——一元多项式相加(C语言版本)
热门文章
- 编写高性能的托管应用程序:入门
- halcon select_shape_xld按区域大小描绘xld
- 音视频同步系列文章之------时间戳与时间尺度(time scale)
- C++类的构造函数 后单冒号加基类 例如:CAboutDlg::CAboutDlg() : CDialogEx(CAboutDlg::IDD)
- PROFINET及其同步实时通讯分析
- Doxygen for C++使用说明——注释代码一
- 后端开发需要学什么_都2020年了,还在纠结学什么语言?| 后端篇
- 原生php登录注册,原生php登陆注册
- Codeforces - 65D - Harry Potter and the Sorting Hat - 简单搜索
- NGINX生命周期-转