闲来无事,整顿一下JavaScript中那些神乎其神的技能,伪装大牛的模样
1. 字符串转换为数字
var a = "123";
console.log(+a); // 123
console.log(typeof +a); // number
// 一样可用于日期转换为数值:
var b = +new Date(); // 1468545682168
2. 数值向下取整
var a = ~~3.14; // 3
var b = 3.14>>0; // 3
var c = 3.14|0; // 3
3. 字符串转换为数值并取整<!– more –>
var a = "3.14"|0; // 3
var b = "3.14"^0; // 3
感谢 @最先进修前端 斧正,该取整直接去除小数点后数字,仅对正数有用
4. 函数设置默认值
function func(arg){
var arg = arg || "default";
// arg 为 undefined, null, "", 0, false, NaN 时末了都获得"default"
}
5. 变量值交流
var a = 1,
b = 2;
a = [b, b = a][0];
console.log(a); // 2
console.log(b); // 1
6. 运用for in
遍历对象取到属性名与属性
var obj = {
a: 1,
b: 2
}
for(var i in obj) {
console.log("obj." + i + " = " + obj[i]);
}
// output: obj.a = 1
// obj.b = 2
7. 截断数组
var arr = [1, 2, 3, 4, 5, 6];
arr.length = 3;
console.log(arr); // [1, 2, 3]
8. 进步遍历较大Enumerable数据的机能
var arr = [1, 2, 3, 4, 5, 6, ...];
var len = arr.length; // 缓存arr.length
for(var i = 0; i < len; i++) {
console.log(arr[i]);
}
// 也可将缓存写在for的声明中
for(var i = 0, len = a.length; i < len; i++) {
console.log(arr[i]);
}
// 或许(!注重:若数组中键值存在undefined、null、0、false等数据时会中缀遍历)
for(var i = 0, a; a = arr[i++];) {
console.log(a);
}
9. 运用 &&
替换单一前提推断
// 你能够如许写过
if(!token) {
login();
}
// 实在如许也能够
!token && login();
// 或
token || login();
10. 检测 对象/数组 中是不是有指定 属性/元素
var CURD = {
add: function() {},
delete: function() {},
edit: function() {}
}
console.log("add" in CURD); // true
console.log("find" in CURD); // false
/* 误 */
// var arr = [1, 2, 3];
// console.log(1 in arr); // true
// console.log(6 in arr); // false
感谢 @zaaack 斧正,数组的存在检测实质上是检测的是数组下标
11. 经由过程闭包挪用setTimeout
for(var i = 0; i < 10; i++) {
setTimeout(function(){
console.log(i); // 10 10 10 ...
},500);
}
for(var i = 0; i < 10; i++) {
(function(i){
setTimeout(function(){
console.log(i); // 0 1 2 3 ...
},500)
})(i);
}