帮你提高开发效率的JavaScript20个技巧


Posted in Javascript onJune 18, 2021
目录
  • 1. 申明和初始化数组
  • 2.进行求和、最小值和最大值
  • 3. 对字符串、数字或对象的数组进行排序
  • 4. 是否需要从一个数组中过滤掉无用的值?
  • 5. 为各种条件使用逻辑运算符
  • 6. 删除重复的值
  • 7. 创建一个计数器对象或Map
  • 8. 三元运算符很酷
  • 9. 与传统的once相比,for循环更快。
  • 10. 合并两个对象
  • 11. 箭头函数
  • 12. 可选链式
  • 13. 打乱一个数组
  • 14. 空值合并运算符
  • 15. Rest & Spread 运算符
  • 16. 缺省参数
  • 17. 将十进制转换为二进制或十六进制
  • 18. 使用解构简单交换2个值
  • 19. 单行回文检查
  • 20. 将对象的属性变成一个数组的属性
  • 总结

减少代码行数和加快开发的技术!

我们在开发中,经常要写一些函数,如排序、搜索、寻找唯一的值、传递参数、交换值等,在这里我列出了我搜集的一些技术资源,可以像高手一样写出这些函数!

帮你提高开发效率的JavaScript20个技巧

这些方法肯定会对你有帮助:

  • 减少LOC(代码行)的数量
  • 编码竞
  • 黑客马拉松
  • 或者其他限时任务

这些JavaScript黑客技术大多使用ECMAScript6(ES2015)以后的技术,尽管最新版本是ECMAScript11(ES2020)。

注意:下面所有的技巧都是在谷歌浏览器的控制台测试的。

 

1. 申明和初始化数组

可以用默认值来初始化特定大小的数组,如""、null或0。你可能已经把这些用于一维数组,但如何初始化二维数组/矩阵呢?

const array = Array(5).fill(''); 
// Output 
(5) ["", "", "", "", ""]
const matrix = Array(5).fill(0).map(()=>Array(5).fill(0)); 
// Output
(5) [Array(5), Array(5), Array(5), Array(5), Array(5)]
0: (5) [0, 0, 0, 0, 0]
1: (5) [0, 0, 0, 0, 0]
2: (5) [0, 0, 0, 0, 0]
3: (5) [0, 0, 0, 0, 0]
4: (5) [0, 0, 0, 0, 0]
length: 5

 

2.进行求和、最小值和最大值

使用reduce方法来快速进行基本的数学运算。

const array  = [5,4,7,8,9,2];

求和

array.reduce((a,b) => a+b);
// Output: 35

最大值

array.reduce((a,b) => a>b?a:b);
// Output: 9

最小值

array.reduce((a,b) => a<b?a:b);
// Output: 2

 

3. 对字符串、数字或对象的数组进行排序

有内置的sort()和reverse()方法来对字符串进行排序,但对数字或对象数组的排序呢?
数字和对象的排序技巧,可以按照递增和递减的顺序进行排序。

字符串排序

const stringArr = ["Joe", "Kapil", "Steve", "Musk"]
stringArr.sort();
// Output
(4) ["Joe", "Kapil", "Musk", "Steve"]
stringArr.reverse();
// Output
(4) ["Steve", "Musk", "Kapil", "Joe"]

数字排序

const array  = [40, 100, 1, 5, 25, 10];
array.sort((a,b) => a-b);
// Output
(6) [1, 5, 10, 25, 40, 100]
array.sort((a,b) => b-a);
// Output
(6) [100, 40, 25, 10, 5, 1]

对象排序

const objectArr = [ 
    { first_name: 'Lazslo', last_name: 'Jamf'     },
    { first_name: 'Pig',    last_name: 'Bodine'   },
    { first_name: 'Pirate', last_name: 'Prentice' }
];
objectArr.sort((a, b) => a.last_name.localeCompare(b.last_name));
// Output
(3) [{…}, {…}, {…}]
0: {first_name: "Pig", last_name: "Bodine"}
1: {first_name: "Lazslo", last_name: "Jamf"}
2: {first_name: "Pirate", last_name: "Prentice"}
length: 3

 

4. 是否需要从一个数组中过滤掉无用的值?

像0,undefined,null,false,"",''这样的值可以通过下面的技巧轻松过滤。

const array = [3, 0, 6, 7, '', false];
array.filter(Boolean);
// Output
(3) [3, 6, 7]

 

5. 为各种条件使用逻辑运算符

如果你想减少嵌套,比如if...else或switch,可以使用逻辑运算符AND/OR。

function doSomething(arg1){ 
    arg1 = arg1 || 10; 
// set arg1 to 10 as a default if it's not already set
return arg1;
}
let foo = 10;  
foo === 10 && doSomething(); 
// is the same thing as if (foo == 10) then doSomething();
// Output: 10
foo === 5 || doSomething();
// is the same thing as if (foo != 5) then doSomething();
// Output: 10

 

6. 删除重复的值

你可能已经在for循环中使用了indexOf(),它返回第一个找到的索引,或者使用较新的includes(),它从数组中返回布尔值true/false,以找出/删除重复的值。这里我们有两种更快捷的方法。

const array  = [5,4,7,8,9,2,7,5];
array.filter((item,idx,arr) => arr.indexOf(item) === idx);
// or
const nonUnique = [...new Set(array)];
// Output: [5, 4, 7, 8, 9, 2]

 

7. 创建一个计数器对象或Map

很多时候,需要通过创建计数器对象或Map来解决问题,该对象以变量为键,以其频率/出现次数为值来跟踪变量。

let string = 'kapilalipak';
const table={}; 
for(let char of string) {
  table[char]=table[char]+1 || 1;
}
// Output
{k: 2, a: 3, p: 2, i: 2, l: 2}

const countMap = new Map();
  for (let i = 0; i < string.length; i++) {
    if (countMap.has(string[i])) {
      countMap.set(string[i], countMap.get(string[i]) + 1);
    } else {
      countMap.set(string[i], 1);
    }
  }
// Output
Map(5) {"k" => 2, "a" => 3, "p" => 2, "i" => 2, "l" => 2}

 

8. 三元运算符很酷

你可以用三元运算符避免嵌套条件if...elseif...elseif。

function Fever(temp) {
    return temp > 97 ? 'Visit Doctor!'
      : temp < 97 ? 'Go Out and Play!!'
      : temp === 97 ? 'Take Some Rest!';
}
// Output
Fever(97): "Take Some Rest!" 
Fever(100): "Visit Doctor!"

 

9. 与传统的once相比,for循环更快。

for 和 for...in 默认会得到索引,但你可以使用 arr[index]。

for...in也接受非数字,所以要避免它。

forEach,for...of可以直接得到元素。

forEach也可以得到索引,但for...of不能。

 

10. 合并两个对象

在日常工作中,我们经常需要合并多个对象。

const user = { 
 name: 'Kapil Raghuwanshi', 
 gender: 'Male' 
 };
const college = { 
 primary: 'Mani Primary School', 
 secondary: 'Lass Secondary School' 
 };
const skills = { 
 programming: 'Extreme', 
 swimming: 'Average', 
 sleeping: 'Pro' 
 };
const summary = {...user, ...college, ...skills};
// Output 
gender: "Male"
name: "Kapil Raghuwanshi"
primary: "Mani Primary School"
programming: "Extreme"
secondary: "Lass Secondary School"
sleeping: "Pro"
swimming: "Average"

 

11. 箭头函数

箭头函数表达式是传统函数表达式的一个紧凑的替代方案,但它有局限性,不能在所有情况下使用。因为它们有词法范围(parental scope),没有自己的this和arguments,因此它们指的是它们被定义的环境。

const person = {
name: 'Kapil',
sayName() {
    return this.name;
    }
}
person.sayName();
// Output
"Kapil"

箭头函数改写为:

const person = {
name: 'Kapil',
sayName() {
    return this.name;
    }
}
person.sayName();
// Output
"Kapil"

 

12. 可选链式

如果在?之前的值是未定义的或空的,可选链式?就会停止评估,并返回未定义。

const user = {
  employee: {
    name: "Kapil"
  }
};
user.employee?.name;
// Output: "Kapil"
user.employ?.name;
// Output: undefined
user.employ.name
// Output: VM21616:1 Uncaught TypeError: Cannot read property 'name' of undefined

 

13. 打乱一个数组

使用内置的Math.random()方法。

const list = [1, 2, 3, 4, 5, 6, 7, 8, 9];
list.sort(() => {
    return Math.random() - 0.5;
});
// Output
(9) [2, 5, 1, 6, 9, 8, 4, 3, 7]
// Call it again
(9) [4, 1, 7, 5, 3, 8, 2, 9, 6]

 

14. 空值合并运算符

空值合并运算符(??)是一个逻辑运算符,当其左侧的操作数为空或未定义时,返回其右侧的操作数,否则返回其左侧的操作数。

const foo = null ?? 'my school';
// Output: "my school"
const baz = 0 ?? 42;
// Output: 0

 

 

15. Rest & Spread 运算符

那些神秘的3个点...可以Rest或Spread!

function myFun(a,  b, ...manyMoreArgs) {
   return arguments.length;
}
myFun("one", "two", "three", "four", "five", "six");
// Output: 6

const parts = ['shoulders', 'knees']; 
const lyrics = ['head', ...parts, 'and', 'toes']; 
lyrics;
// Output: 
(5) ["head", "shoulders", "knees", "and", "toes"]

 

16. 缺省参数

const search = (arr, low=0,high=arr.length-1) => {
    return high;
}
search([1,2,3,4,5]);
// Output: 4

 

17. 将十进制转换为二进制或十六进制

我们可以使用一些内置的方法,如.toPrecision()或.toFixed()来帮助实现此类问题。

num.toString(2);
// Output: "1010"
num.toString(16);
// Output: "a"
num.toString(8);
// Output: "12"

 

18. 使用解构简单交换2个值

let a = 5;
let b = 8;
[a,b] = [b,a]
[a,b]
// Output
(2) [8, 5]

 

19. 单行回文检查

function checkPalindrome(str) {
  return str == str.split('').reverse().join('');
}
checkPalindrome('naman');
// Output: true

 

20. 将对象的属性变成一个数组的属性

使用Object. entries(),Object.key()和Object.values()。

const obj = { a: 1, b: 2, c: 3 };
Object.entries(obj);
// Output
(3) [Array(2), Array(2), Array(2)]
0: (2) ["a", 1]
1: (2) ["b", 2]
2: (2) ["c", 3]
length: 3
Object.keys(obj);
(3) ["a", "b", "c"]
Object.values(obj);
(3) [1, 2, 3]

 

总结

我整理的就这些了,希望大家可以关注三水点靠木其他文章!

Javascript 相关文章推荐
js模拟弹出效果代码修正版
Aug 07 Javascript
JS input 数字验证代码
Jul 30 Javascript
关于javascript中的parseInt使用技巧
Sep 03 Javascript
JavaScript 函数调用规则
Sep 14 Javascript
ext 同步和异步示例代码
Sep 18 Javascript
原始XMLHttpRequest方法详情回顾
Nov 28 Javascript
js禁止页面刷新与后退的方法
Jun 08 Javascript
JavaScript中的Math.SQRT1_2属性使用简介
Jun 14 Javascript
js实现可折叠展开的手风琴菜单效果
Sep 07 Javascript
webpack处理 css\less\sass 样式的方法
Aug 21 Javascript
webpack4与babel配合使es6代码可运行于低版本浏览器的方法
Oct 12 Javascript
Vue.js页面中有多个input搜索框如何实现防抖操作
Nov 04 Javascript
JavaScript实现贪吃蛇游戏
Vue过滤器(filter)实现及应用场景详解
GitHub上77.9K的Axios项目有哪些值得借鉴的地方详析
Axios取消重复请求的方法实例详解
使用JS实现简易计算器
微信小程序实现聊天室功能
小程序实现文字循环滚动动画
You might like
phpmyadmin MySQL 加密配置方法
2009/07/05 PHP
php数组函数序列之asort() - 对数组的元素值进行升序排序,保持索引关系
2011/11/02 PHP
PHP exif扩展方法开启详解
2014/07/28 PHP
使用Yii2实现主从数据库设置
2016/11/20 PHP
学习javascript,实现插入排序实现代码
2011/07/31 Javascript
jquery实现背景墙聚光灯效果示例分享
2014/03/02 Javascript
js 判断浏览器使用的语言示例代码
2014/03/22 Javascript
javascript生成随机数的方法
2014/05/16 Javascript
微信小程序 教程之数据绑定
2016/10/18 Javascript
Angular2学习笔记——详解路由器模型(Router)
2016/12/02 Javascript
AngularJS实现根据不同条件显示不同控件
2017/04/20 Javascript
详解React项目中碰到的IE问题
2019/03/14 Javascript
微信小程序学习笔记之登录API与获取用户信息操作图文详解
2019/03/29 Javascript
layer设置maxWidth及maxHeight解决方案
2019/07/26 Javascript
再也不怕 JavaScript 报错了,怎么看怎么处理都在这儿
2020/12/09 Javascript
python利用hook技术破解https的实例代码
2013/03/25 Python
Python 元组(Tuple)操作详解
2014/03/11 Python
详解Python中的多线程编程
2015/04/09 Python
python实现下载文件的三种方法
2017/02/09 Python
浅谈numpy数组的几种排序方式
2017/12/15 Python
对pandas数据判断是否为NaN值的方法详解
2018/11/06 Python
基于python实现高速视频传输程序
2019/05/05 Python
python检查目录文件权限并修改目录文件权限的操作
2020/03/11 Python
Python动态导入模块:__import__、importlib、动态导入的使用场景实例分析
2020/03/30 Python
10张动图学会python循环与递归问题
2021/02/06 Python
CSS3属性使网站设计增强同时不消弱可用性
2009/08/29 HTML / CSS
飞利浦法国官网:Philips法国
2019/07/10 全球购物
高中班主任评语大全
2014/04/25 职场文书
六年级小学生评语
2014/12/26 职场文书
涪陵白鹤梁导游词
2015/02/09 职场文书
大学班干部竞选稿
2015/11/20 职场文书
2016年学习雷锋精神广播稿
2015/12/17 职场文书
小学英语新课改心得体会
2016/01/22 职场文书
使用 Apache Dubbo 实现远程通信(微服务架构)
2022/02/12 Servers
详细介绍python操作RabbitMq
2022/04/12 Python
CentOS MySql8 远程连接实战
2022/04/19 MySQL