1.转换为数字
使用加法运算符+可以快速实现相反的效果。
let int = "15";
int = +int;
console.log(int); // Result: 15
console.log(typeof int);
Result: "number";
这也可以用于将布尔值转换为数字,如下所示
console.log(+true); // Return: 1
console.log(+false); // Return: 0
在某些上下文中,+将被解释为连接操作符,而不是加法操作符。当这种情况发生时(你希望返回一个整数,而不是浮点数),您可以使用两个波浪号:~~。
连续使用两个波浪有效地否定了操作,因为— ( — n — 1) — 1 = n + 1 — 1 = n。 换句话说,~—16 等于15。
const int = ~~"15";
console.log(int); // Result: 15
console.log(typeof int);
Result: "number";
按位 NOT 运算符也可以用在布尔值上:~true = -2和~false = -1。
2.性能更好的运算
从 ES7 开始,可以使用指数运算符**作为幂的简写,这比编写Math.pow(2, 3) 更快。 这是很简单的东西,但它之所以出现在列表中,是因为没有多少教程更新过这个操作符。
console.log(2 ** 3); // Result: 8
这不应该与通常用于表示指数的^符号相混淆,但在 JavaScript 中它是按位异或运算符。
在 ES7 之前,只有以2为基数的幂才存在简写,使用按位左移操作符<<
Math.pow(2, n);
2 << (n - 1);
2 ** n;
例如,2 << 3 = 16等于2 ** 4 = 16。
3.快速浮点数转整数
如果希望将浮点数转换为整数,可以使用Math.floor()、Math.ceil()或Math.round()。但是还有一种更快的方法可以使用|(位或运算符)将浮点数截断为整数。
console.log(23.9 | 0); // Result: 23
console.log(-23.9 | 0); // Result: -23
|的行为取决于处理的是正数还是负数,所以最好只在确定的情况下使用这个快捷方式。
如果n为正,则n | 0有效地向下舍入。 如果n为负数,则有效地向上舍入。 更准确地说,此操作将删除小数点后面的任何内容,将浮点数截断为整数。
你可以使用~~来获得相同的舍入效果,如上所述,实际上任何位操作符都会强制浮点数为整数。这些特殊操作之所以有效,是因为一旦强制为整数,值就保持不变。
删除最后一个数字
按位或运算符还可以用于从整数的末尾删除任意数量的数字。这意味着我们不需要使用这样的代码来在类型之间进行转换。
let str = "1553";
Number(str.substring(0, str.length - 1));
相反,按位或运算符可以这样写:
console.log((1553 / 10) | 0); // Result: 155
console.log((1553 / 100) | 0); // Result: 15
console.log((1553 / 1000) | 0); // Result: 1
4.获取数组中的最后一项
数组方法slice()可以接受负整数,如果提供它,它将接受数组末尾的值,而不是数组开头的值。
let array = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
console.log(array.slice(-1)); // Result: [9]
console.log(array.slice(-2)); // Result: [8, 9]
console.log(array.slice(-3)); // Result: [7, 8, 9]
5.巧用逻辑运算符
且运算符(&&)
且运算符的运算规则是:如果第一个运算子的布尔值为true,则返回第二个运算子的值(注意是值,不是布尔值);如果第一个运算子的布尔值为false,则直接返回第一个运算子的值,且不再对第二个运算子求值。
if(is){
run()
}
// 等价于
is && run()
或运算符(||)
或运算符的运算规则是:如果第一个运算子的布尔值为true,则返回第一个运算子的值,且不再对第二个运算子求值;如果第一个运算子的布尔值为false,则返回第二个运算子的值。
function run(evt){
var evt=evt||window.event;
}
var num = 1;
true || (num = 2) // true
6.合并对象
在JavaScript中合并多个对象的需求已经存在,尤其是当我们开始使用选项创建类和小部件时:
const person={name:"Tony",gender:"male"};
const attr={skill:"造型"};
// 第一种
let newobj=Object.assign({},person,attr);
// 第二种(更简化)
let summary = {...person, ...attr};
7.数组去重
使用ES6全新的数据结构即可简单实现。
var j = [...new Set([1, 2, 3, 3])]
输出: [1, 2, 3]
ES6详细语法可以查看ES6文档
8.优化你的switch语句
优化前:
const dogSwitch=(branch)=>{
switch(branch){
case "develop":
return "http://develop.com"
break
case "test":
return "http://test.com"
break
case "uat":
return "http://uat.com"
break
case "prd":
return "http://prd.com"
break
default:
return "http://prd.com"
}
}
dogSwitch("uat")
优化后:
const dogSwitch = (branch) =>({
"develop": "http://develop.com",
"test": "http://test.com",
"uat": "http://uat.com",
"prd": "http://prd.com"
})[branch]||"http://prd.com";
dogSwitch("uat")
感谢你的阅读
多多指导哦
如果觉得喜欢,就收藏一下或者star一下呗,或者也可以给我的github来颗 star~~