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中继承任何属性或则方法(比如constructortoString()等)

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实用技巧相关推荐

  1. 2个实用的JS小技巧

    如何优雅的捕获错误 之前的经常会出现这样的代码逻辑: // 假设这是一个API接口调用 function userInfo () {return new Promise((resolve, rejec ...

  2. 快过年了,分享 25 个 JS 实用技巧送给大家吧

    本文主要介绍一些JS中用到的小技巧,可以在日常Coding中提升幸福度,将不定期更新~ 类型强制转换 1.1 string强制转换为数字 可以用 *1来转化为数字(实际上是调用 .valueOf方法) ...

  3. 这10个实用的Javascript调试技巧,你知道吗?

    见过太多同学调试Javascript只会用简单的console.log甚至alert,看着真为他们着急.因为大多数同学追求优雅而高效地写代码,却忽略了如何优雅而高效地调试代码,不得不说是有点" ...

  4. 助你掌握搜索神器,10个实用的Elasticsearch查询技巧

    前言   Elasticsearch是一个非常流行的搜索引擎,已经成为了许多企业的首选解决方案.然而,我们要想成为一个优秀的程序员,就必须掌握各种查询技巧.本文将向大家介绍10个实用的Elastics ...

  5. Mac电脑高手都会用的10个Mac OS实用技巧,都是干货值得收藏!

    Mac OS中其实有很多隐藏实用的功能,但是因为各种各样的原因,它们没能进入用户的视线.工欲善其事,必先利其器.好的工具可以提高生产效率,熟练的使用各种技巧可以事半功倍.今天,小编给大家带来了10个你 ...

  6. 办公技巧:分享12个实用的word小技巧,欢迎收藏!

    今天给大家分享12个实用的word小技巧,希望对大家能有所帮助! 1. Word表格自动填充序号 在Word表格里选中要填入相同内容的单元格,单击"格式→项目符号和编号",进入&q ...

  7. 前端:分享一些实用的JS代码片段

    今天给大家分享一些实用的JS代码片段,有需要的朋友欢迎收藏! 1.获取浏览器的版本 function getBrowser() {var UserAgent = navigator.userAgent ...

  8. 继续分享 5 个实用的 vs 调试技巧

    前言 我在上一篇文章????<5 个非常实用的 vs 调试技巧> 中分享了 5 个我认为非常值得了解的 vs 调试技巧,本周继续分享 5 个很基础但同样实用的调试技巧. 1. 条件断点 作 ...

  9. 计算机办公软件的使用技巧,实用的Word小技巧集锦(1)办公软件知识 -电脑资料

    一,把文字替换成图片 首先把图片复制到 剪贴板中,然后打开替换对话框,在"查找内容"框中输入将被替换的文字,接着在"替换为"框中输入"^c" ...

最新文章

  1. 学习JS面向对象成果,借国庆发布个最新作品与大家交流
  2. JAVA Thread线程异常监控
  3. Spring MVC普通类或工具类中调用service报空空指针的解决办法(调用service报java.lang.NullPointerException)...
  4. Redis实战(二):Redis 的 String 类型 bitmap
  5. (转)解读NTFS(一)
  6. python:第一个简单爬虫程序
  7. django 1.8 官方文档翻译: 2-5-10 数据库函数
  8. 推荐学习网页标准的20个好去处
  9. 深入解析Mysql 主从同步延迟原理及解决方案
  10. RTX2009管理器服务运行状态空白
  11. Python编程——实现屏幕广告语的滚动
  12. logrotate 管理日志文件不生效
  13. Android 中app加固与瘦身
  14. 时间晶体,一种曾被认为是无法存在的物质,被创造出来了吗?
  15. 初识机器阅读理解(Machine Reading Comprehension)
  16. HDU-6578 Blank
  17. phpmyadmin mysql管理器_phpMyAdmin(MySQL的资料库管理工具)
  18. 微信“戒烟”了!网友:我也戒
  19. 【Excel统计分析插件】上海道宁为您提供统计分析、数据可视化和建模软件——Analyse-it
  20. 数据结构——一元多项式相加(C语言版本)

热门文章

  1. 编写高性能的托管应用程序:入门
  2. halcon select_shape_xld按区域大小描绘xld
  3. 音视频同步系列文章之------时间戳与时间尺度(time scale)
  4. C++类的构造函数 后单冒号加基类 例如:CAboutDlg::CAboutDlg() : CDialogEx(CAboutDlg::IDD)
  5. PROFINET及其同步实时通讯分析
  6. Doxygen for C++使用说明——注释代码一
  7. 后端开发需要学什么_都2020年了,还在纠结学什么语言?| 后端篇
  8. 原生php登录注册,原生php登陆注册
  9. Codeforces - 65D - Harry Potter and the Sorting Hat - 简单搜索
  10. NGINX生命周期-转