一、变量声明

  • 多个变量的声明,可以简写
// 非效率写法
let x;
let y;
let z = 520; // 效率写法
let x, y, z = 520;

二、三元运算符

  • 在条件判断时,可以使用三元运算符增加效率
let num1 = 520;
let num2 = 1314; // 非效率写法
if (num1 > num2) {
// ...
} else {
// ...
} // 效率写法
let result = num1 > num2 ? true : false;

三、解构赋值

  • 变量赋值
let a, b, c;

// 非效率写法
a = 1;
b = 2;
c = 3; // 效率写法
let [a, b, c] = [1, 2, 3];

四、解构交换

  • 交换两个变量
let x = '极客飞兔', y = '程序员';

// 非效率写法
const temp = x;
x = y;
y = temp; // 效率写法
[x, y] = [y, x];

五、箭头函数

  • 函数的简写方式
// 非效率写法
function add(num1, num2) {
return num1 + num2;
} // 效率写法
const add = (num1, num2) => num1 + num2;

六、字符串模版

// 非效率写法
console.log('极客飞兔的年龄 ' + age + ' 他的身高 ' + height); // 效率写法
console.log(`极客飞兔的年龄 ${age} 他的身高 ${height}`);

七、多值匹配

  • 判断某个值是否等于某个多个值中的一个
// 非效率写法
if (value === 1 || value === '飞兔' || value === 2 || value === '程序员') {
// ...
} // 效率写法一
if ([1, '飞兔', 2, '程序员'].indexOf(value) >= 0) {
// ...
} // 效率写法二
if ([1, '飞兔', 2, '程序员'].includes(value)) {
// ...
}

八、ES6对象简写

let firstname = '极客';
let lastname = '飞兔'; // 非效率写法
let userinfo = {firstname: firstname, lastname: lastname}; // 效率写法
let userinfo = {firstname, lastname};

九、字符串转数字

// 非效率写法
let total = parseInt('520');
let average = parseFloat('13.14'); // 效率写法
let total = +'520';
let average = +'13.14';

十、次方相乘

// 非效率写法
const power = Math.pow(2, 5); // 效率写法
const power = 2**5;

十一、数组合并

let arr1 = [520, 1314];

// 非效率写法
let arr2 = arr1.concat([1225, 1115]); // 效率写法
let arr2 = [...arr1, 1225, 1115];

十二、查找数组最大值最小值

const arr = [520, 1314, 1115, 1225];

// 效率写法
Math.max(...arr);
Math.min(...arr);

十三、获取字符串字符

let str = 'https://autofelix.blog.csdn.net/';

// 非效率写法
str.charAt(10); // 效率写法
str[10];

十四、并&&操作

function fn() {
return true;
} let flag = true; // 非效率写法
if (flag) {
fn();
} // 效率写法
flag && fn();

十五、数组排序

const arr = [40, 2, 1, 5, 99, 111];

// 从小到大
arr.sort((a, b) => a - b); // [1, 2, 5, 40, 99, 111] // 从大到小
arr.sort((a, b) => b - a); // [111, 99, 40, 5, 2, 1]

十六、数组过滤

  • 从数组中过滤假数值
const arr = [3, '1', '', 0, false, null, undefined];

arr.filter(Boolean); // [3, '1']

十七、for循环

let arr = ['极客飞兔', 520, 1314, '程序员']

// 非效率写法
for (var i = 0; i < arr.length; i++) {} // 效率写法
for (const i in arr) {}
// 效率写法
for (const i of arr) {}

十八、判断奇偶

  • 使用& 1 判断奇偶数
// 非效率写法
if(value / 2 == 0) {
// 是偶数
} else {
// 是奇数
} // 效率写法
2 & 1; // 0 返回0表示偶数
3 & 1; // 1 返回1表示奇数

十九、数组去重

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

// 效率的两种写法
array.filter((item,idx,arr) => arr.indexOf(item) === idx);
const nonUnique = [...new Set(array)];

二十、IF检查

// 非效率写法
if (result === true) // 效率写法
if (result)

二十一、合并对象

const user = {
name: '极客飞兔',
gender: '男'
}; const college = {
primary: '清华大学',
secondary: '社会大学'
}; const skills = {
java: 'JAVA',
php: 'PHP',
python: 'PYTHON'
}; const summary = {...user, ...college, ...skills};

二十二、可选链

const user = {
employee: {
name: "极客飞兔"
}
}; // 可选链
user.employee?.name;
user.employ?.name;
user.employ.name;

二十三、字符串重复

// 非效率写法
let str= '';
for(let i = 0; i < 5; i ++) {
str+= 'autofelix ';
} // 效率写法
'autofelix '.repeat(5);

二十四、默认值

let user;
let name = getUserName(); // 非效率写法
if (name !== null && name !== undefined && name !== '') {
user = name;
} else {
user = '极客飞兔';
} // 效率写法
let user = getUserName() || '极客飞兔';

二十五、双波浪线运算符

// 非效率写法
const floor = Math.floor(6.8); // 6 // 效率写法
const floor = ~~6.8; // 6

二十六、移除对象属性

let obj = {x: 45, y: 72, z: 68, p: 98};

// 非效率写法
delete obj.x;
delete obj.p;
console.log(obj); // {y: 72, z: 68} // 效率写法
let {x, p, ...newObj} = obj;
console.log(newObj); // {y: 72, z: 68}

编程技巧│提高 Javascript 代码效率的技巧的更多相关文章

  1. 提高 JavaScript 开发效率的高级 VSCode 扩展!

    原文:提高 JavaScript 开发效率的高级 VSCode 扩展! 作者:前端小智 Fundebug经授权转载,版权归原作者所有. Quokka.js Quokka.js 是一个用于 JavaSc ...

  2. Android 你可能忽略的提高敲代码效率的方式

    Android 你可能忽略的提高敲代码效率的方式

  3. Android 你可能忽略的提高敲代码效率的方式 (转)

    每日推荐 Eyepetizer-in-Kotlin:一款简约的小视频app,带你走进kotlin 作为学习kotlin的一款app,在撸代码的过程中学习kotlin的语法及特性. Eyepetizer ...

  4. JS函数 编程练习 使用javascript代码写出一个函数:实现传入两个整数后弹出较大的整数。

    编程练习 使用javascript代码写出一个函数:实现传入两个整数后弹出较大的整数. 任务 第一步: 编写代码完成一个函数的定义吧. 第二步: 我们来补充函数体中的控制语句,完成函数功能吧. 提示: ...

  5. 巧妙利用函数的惰性载入提高javascript 代码性能

    在 javascript 代码中,因为各浏览器之间的行为的差异,我们经常会在函数中包含了大量的 if 语句,以检查浏览器特性,解决不同浏览器的兼容问题. 例如,我们最常见的为 dom 节点添加事件的函 ...

  6. 利用函数的惰性载入提高 javascript 代码性能

    在 javascript 代码中,因为各浏览器之间的行为的差异,我们经常会在函数中包含了大量的 if 语句,以检查浏览器特性,解决不同浏览器的兼容问题.例如,我们最常见的为 dom 节点添加事件的函数 ...

  7. 去哪儿网2017校招在线笔试(前端工程师)编程题及JavaScript代码

    编程题很简单.整个试卷结构为: 一.问答题: 对前端的理解,了解哪些框架库? 二.在线编程题:身份证分组 如下第一道:身份证分组 三.在线编程题:身份证分组.统计字符.酒店价格(三选二) 如下第二三四 ...

  8. 如何提高JavaScript代码质量

    如何编写可维护的JavaScript代码 代码风格及规范 构建检查工具 jshint配置 http://jshint.com/docs/options/ http://www.cnblogs.com/ ...

  9. 五十个小技巧提高PHP执行效率(二)

    更详细具体的总结如下: 1.用单引号代替双引号来包含字符串,这样做会更快一些.因为PHP会在双引号包围的字符串中搜寻变量, 单引号则不会,注意:只有echo能这么做,它是一种可以把多个字符串当作参数的 ...

随机推荐

  1. Hyperledger Fabric无系统通道启动及通道的创建和删除

    前言 在Hyperledger Fabric组织的动态添加和删除中,我们已经完成了在运行着的网络中动态添加和删除组织,但目前为止,我们启动 orderer 节点的方式都是通过系统通道的方式,这样自带系 ...

  2. Redis4.0.14 迁槽失败

    线上一个redis集群中主节点使用的内存达到了9.78g,按照redis单个实例最大内存不要超出10g的规范,扩容操作就放在了今天晚上进行.因为之前redis迁槽都是采用 redis-trib.rb ...

  3. Educational Codeforces Round 121 (Rated for Div. 2)——A - Equidistant Letters

    A - Equidistant Letters 题源:https://codeforces.com/contest/1626/problem/A 今天上午VP了这场CF,很遗憾的是一道题也没写出来,原 ...

  4. 『现学现忘』Git基础 — 8、Git创建本地版本库

    目录 1.Git版本库介绍 2.创建本地版本库 场景一:创建一个空的本地版本库. 场景二:项目中已存在文件时,创建该项目的本地版本库. 场景三:在GitHub网站上创建仓库,克隆到本地. 1.Git版 ...

  5. 企业级 Web 开发的挑战

    本文翻译自土牛Halil ibrahim Kalkan的<Mastering ABP Framework>,是系列翻译的起头,适合ABP开发人员或者想对ABP框架进行深入演进的准架构师. ...

  6. XGBoost文本分类,多分类、二分类、10-Fold(K-Fold)

    做机器学习的时候经常用到XGB,简单记录一下 K折交叉验证也是模型常用的优化方法.一起记录... K折交叉验证:类似三个臭皮匠,顶个诸葛亮.我的理解是,就是用民主投票的方式,选取票数最高的那个当结果. ...

  7. WPFApplication类

    Application类 应用程序类Application,以下代码自动生成且在程序中不可见,定义程序入口点方法以及程序启动程序,整个程序生命周期为执行完Main()方法里的程序.对于自定义的应用程序 ...

  8. mybaitis查询 (数据库与实体类字段名不相同)

    1.这是我的数据库字段名和实体类字段名 2.方法 方法一: 查询的结果标题 会跟实体类的属性一一匹配,一定要一致就算数据库字段和属性不一致,我们可以把查询结果设置一个别名,让别名=属性名 方法二:使用 ...

  9. 基于SqlSugar的开发框架循序渐进介绍(2)-- 基于中间表的查询处理

    在前面介绍的SqlSugar的相关查询处理操作中,我们主要以单表的方式生成相关的实体类,并在查询的时候,对单表的字段进行条件的对比处理,从而返回对应的数据记录.本篇随笔介绍在一些外键或者中间表的处理中 ...

  10. PCIe引脚PRSNT与热插拔

    热插拔的基本目的是要让PCIe设备按照规定的顺序.原则,从系统中移除或插入到系统中来,并能正常的工作,且不影响系统的正常运行.事实上,PCIe"热插拔"的关键目的就是为前面面所提到 ...