编程技巧│提高 Javascript 代码效率的技巧
一、变量声明
- 多个变量的声明,可以简写
// 非效率写法
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 代码效率的技巧的更多相关文章
- 提高 JavaScript 开发效率的高级 VSCode 扩展!
原文:提高 JavaScript 开发效率的高级 VSCode 扩展! 作者:前端小智 Fundebug经授权转载,版权归原作者所有. Quokka.js Quokka.js 是一个用于 JavaSc ...
- Android 你可能忽略的提高敲代码效率的方式
Android 你可能忽略的提高敲代码效率的方式
- Android 你可能忽略的提高敲代码效率的方式 (转)
每日推荐 Eyepetizer-in-Kotlin:一款简约的小视频app,带你走进kotlin 作为学习kotlin的一款app,在撸代码的过程中学习kotlin的语法及特性. Eyepetizer ...
- JS函数 编程练习 使用javascript代码写出一个函数:实现传入两个整数后弹出较大的整数。
编程练习 使用javascript代码写出一个函数:实现传入两个整数后弹出较大的整数. 任务 第一步: 编写代码完成一个函数的定义吧. 第二步: 我们来补充函数体中的控制语句,完成函数功能吧. 提示: ...
- 巧妙利用函数的惰性载入提高javascript 代码性能
在 javascript 代码中,因为各浏览器之间的行为的差异,我们经常会在函数中包含了大量的 if 语句,以检查浏览器特性,解决不同浏览器的兼容问题. 例如,我们最常见的为 dom 节点添加事件的函 ...
- 利用函数的惰性载入提高 javascript 代码性能
在 javascript 代码中,因为各浏览器之间的行为的差异,我们经常会在函数中包含了大量的 if 语句,以检查浏览器特性,解决不同浏览器的兼容问题.例如,我们最常见的为 dom 节点添加事件的函数 ...
- 去哪儿网2017校招在线笔试(前端工程师)编程题及JavaScript代码
编程题很简单.整个试卷结构为: 一.问答题: 对前端的理解,了解哪些框架库? 二.在线编程题:身份证分组 如下第一道:身份证分组 三.在线编程题:身份证分组.统计字符.酒店价格(三选二) 如下第二三四 ...
- 如何提高JavaScript代码质量
如何编写可维护的JavaScript代码 代码风格及规范 构建检查工具 jshint配置 http://jshint.com/docs/options/ http://www.cnblogs.com/ ...
- 五十个小技巧提高PHP执行效率(二)
更详细具体的总结如下: 1.用单引号代替双引号来包含字符串,这样做会更快一些.因为PHP会在双引号包围的字符串中搜寻变量, 单引号则不会,注意:只有echo能这么做,它是一种可以把多个字符串当作参数的 ...
随机推荐
- 函数 装饰器 python
今日内容概要 1.闭包函数 2.闭包函数的实际应用 3.装饰器简介(重点加难点) 4.简易版本装饰器 5.进阶版本装饰器 6.完整版本装饰器 7.装饰器模板(拷贝使用即可) 8.装饰器语法糖 9.装饰 ...
- Python 速通爆肝、列表推导式、生成器、装饰器、生命游戏
列表推导式.赋值.切片(替换.插入).字符串处理与判断.enumerate().格式化字符串.读写文件.global 关键字.字符串startswith().类与对象.生成器.装饰器.Self.*ar ...
- Zabbix-Proxy 部署和运行
Zabbix-Proxy 部署&运行 前提 版本: zabbix-server 5.4 任务: 通过SNMP监控网络设备,需要需通过zabbix-proxy 发送到zabbix-server. ...
- 【技术积累】Eclipse使用系列【第一版】
Eclipse安装(Neon版本) Eclipse 最新版本 Eclipse Neon,这个首次鼓励用户使用 Eclipse Installer 来做安装,这是一种由Eclipse Oomph提供的新 ...
- OpenHarmony 3.1 Beta 版本关键特性解析——ArkUI canvas组件
(以下内容来自开发者分享,不代表 OpenHarmony 项目群工作委员会观点) 江英杰 华为技术有限公司 canvas 是 ArkUI 开发框架里的画布组件,常用于自定义绘制图形.因为其轻量.灵活. ...
- OpenHarmony标准设备应用开发(三)——分布式数据管理
(以下内容来自开发者分享,不代表 OpenHarmony 项目群工作委员会观点) 邢碌 上一章,我们通过分布式音乐播放器.分布式炸弹.分布式购物车,带大家讲解了 OpenAtom OpenHarmon ...
- Java第十四周作业
2.设计2个类,要求如下:(知识点:类的继承 方法的覆 盖) [必做题] 2.1 定义一个汽车类Vehicle, 2.1.1 属性包括:汽车品牌brand(String类型).颜色clr (Strin ...
- cookie和localstorge、sessionStorge的区别
一.背景由来 cookie原来是用来网络请求携带用户信息的,只不过在HTML5出现之前,前端没有本地存储的方法,只能使用cookie代替 localstorge.sessionStorge是html5 ...
- .NET MAUI发布了期待已久的候选版本(RC1)
作者:David Ortinau 我们激动地宣布在4/13/2022.NET多平台应用UI (.NET MAUI)发布了候选版本.SDK现在已经集成好了API,可以更新库,并为GA(通用可用性)兼容性 ...
- Http GET 请求参数中文乱码
两种解决方式 第1种:代码里转换 String name = request.getParamter("name"); String nameUtf8 = new String(n ...