12个JavaScript技巧
2016-05-20 17:29
519 查看
转自:http://web.jobbole.com/86146/
在这篇文章中将给大家分享12个有关于JavaScript的小技巧。这些小技巧可能在你的实际工作中或许能帮助你解决一些问题。
使用
有时候我们需要对一个变量查检其是否存在或者检查值是否有一个有效值,如果存在就返回
在这个示例中,只要
使用
这个技巧非常有用,其非常简单,可以交字符串数据转换成数字,不过其只适合用于字符串数据,否则将返回
这个也适用于
你也可以将变量简写,并且使用
如果一些属性或函数存在于一个对象中,你也可以这样做检测,如下面的代码所示:
使用
在ES6中有默认参数这一特性。为了在老版本的浏览器中模拟这一特性,可以使用
在循环中缓存
这个技巧很简单,这个在处理一个很大的数组循环时,对性能影响将是非常大的。基本上,大家都会写一个这样的同步迭代的数组:
如果是一个小型数组,这样做很好,如果你要处理的是一个大的数组,这段代码在每次迭代都将会重新计算数组的大小,这将会导致一些延误。为了避免这种现象出现,可以将
你也可以写在这样:
在这个示例中,如果
然后这个函数并不适合用来合并两个大型的数组,因为其将消耗大量的内存来存储新创建的数组。在这种情况之个,可以使用
将
如果你运行
在这篇文章中将给大家分享12个有关于JavaScript的小技巧。这些小技巧可能在你的实际工作中或许能帮助你解决一些问题。
使用!!
操作符转换布尔值
有时候我们需要对一个变量查检其是否存在或者检查值是否有一个有效值,如果存在就返回true值。为了做这样的验证,我们可以使用
!!操作符来实现是非常的方便与简单。对于变量可以使用
!!variable做检测,只要变量的值为:
0、
null、
" "、
undefined或者
NaN都将返回的是
false,反之返回的是
true。比如下面的示例:
1 2 3 4 5 6 7 8 9 10 11 | function Account(cash) { this.cash = cash; this.hasMoney = !!cash; } var account = new Account(100.50); console.log(account.cash); // 100.50 console.log(account.hasMoney); // true var emptyAccount = new Account(0); console.log(emptyAccount.cash); // 0 console.log(emptyAccount.hasMoney); // false |
account.cash的值大于
0,那么
account.hasMoney返回的值就是
true。
使用+
将字符串转换成数字
这个技巧非常有用,其非常简单,可以交字符串数据转换成数字,不过其只适合用于字符串数据,否则将返回NaN,比如下面的示例:
1 2 3 4 5 | function toNumber(strNumber) { return +strNumber; } console.log(toNumber("1234")); // 1234 console.log(toNumber("ACB")); // NaN |
Date,在本例中,它将返回的是时间戳数字:
1 | console.log(+new Date()) // 1461288164385 |
并条件符
如果你有一段这样的代码:1 2 3 | if (conected) { login(); } |
&&和函数连接在一起,比如上面的示例,可以简写成这样:
1 | conected && login(); |
1 | user && user.login(); |
使用||
运算符
在ES6中有默认参数这一特性。为了在老版本的浏览器中模拟这一特性,可以使用||操作符,并且将将默认值当做第二个参数传入。如果第一个参数返回的值为
false,那么第二个值将会认为是一个默认值。如下面这个示例:
1 2 3 4 5 6 7 8 9 10 11 | function User(name, age) { this.name = name || "Oliver Queen"; this.age = age || 27; } var user1 = new User(); console.log(user1.name); // Oliver Queen console.log(user1.age); // 27 var user2 = new User("Barry Allen", 25); console.log(user2.name); // Barry Allen console.log(user2.age); // 25 |
在循环中缓存array.length
这个技巧很简单,这个在处理一个很大的数组循环时,对性能影响将是非常大的。基本上,大家都会写一个这样的同步迭代的数组:1 2 3 | for(var i = 0; i < array.length; i++) { console.log(array[i]); } |
array.length做一个缓存:
1 2 3 4 | var length = array.length; for(var i = 0; i < length; i++) { console.log(array[i]); } |
1 2 3 | for(var i = 0, length = array.length; i < length; i++) { console.log(array[i]); } |
检测对象中属性
当你需要检测一些属性是否存在,避免运行未定义的函数或属性时,这个小技巧就显得很有用。如果你打算定些一些跨兼容的浏览器代码,你也可能会用到这个小技巧。例如,你想使用document.querySelector()来选择一个
id,并且让它能兼容IE6浏览器,但是在IE6浏览器中这个函数是不存在的,那么使用这个操作符来检测这个函数是否存在就显得非常的有用,如下面的示例:
1 2 3 4 5 | if ('querySelector' in document) { document.querySelector("#id"); } else { document.getElementById("id"); } |
document不存在
querySelector函数,那么就会调用
docuemnt.getElementById("id")。
获取数组中最后一个元素
Array.prototype.slice(begin,end)用来获取
begin和
end之间的数组元素。如果你不设置
end参数,将会将数组的默认长度值当作
end值。但有些同学可能不知道这个函数还可以接受负值作为参数。如果你设置一个负值作为
begin的值,那么你可以获取数组的最后一个元素。如:
1 2 3 4 | var array = [1,2,3,4,5,6]; console.log(array.slice(-1)); // [6] console.log(array.slice(-2)); // [5,6] console.log(array.slice(-3)); // [4,5,6] |
数组截断
这个小技巧主要用来锁定数组的大小,如果用于删除数组中的一些元素来说,是非常有用的。例如,你的数组有10个元素,但你只想只要前五个元素,那么你可以通过
array.length=5来截断数组。如下面这个示例:
1 2 3 4 5 | var array = [1,2,3,4,5,6]; console.log(array.length); // 6 array.length = 3; console.log(array.length); // 3 console.log(array); // [1,2,3] |
替换所有
String.replace()函数允许你使用字符串或正则表达式来替换字符串,本身这个函数只替换第一次出现的字符串,不过你可以使用正则表达多中的
/g来模拟
replaceAll()函数功能:
1 2 3 | var string = "john john"; console.log(string.replace(/hn/, "ana")); // "joana john" console.log(string.replace(/hn/g, "ana")); // "joana joana" |
合并数组
如果你要合并两个数组,一般情况之下你都会使用Array.concat()函数:
1 2 3 | var array1 = [1,2,3]; var array2 = [4,5,6]; console.log(array1.concat(array2)); // [1,2,3,4,5,6]; |
Array.pus().apply(arr1,arr2)来替代创建一个新数组。这种方法不是用来创建一个新的数组,其只是将第一个第二个数组合并在一起,同时减少内存的使用:
1 2 3 | var array1 = [1,2,3]; var array2 = [4,5,6]; console.log(array1.push.apply(array1, array2)); // [1,2,3,4,5,6]; |
将NodeList
转换成数组
如果你运行document.querySelectorAll(“p”)函数时,它可能返回DOM元素的数组,也就是
NodeList对象。但这个对象不具有数组的函数功能,比如
sort()、
reduce()、
map()、
filter()等。为了让这些原生的数组函数功能也能用于其上面,需要将节点列表转换成数组。可以使用
[].slice.call(elements)来实现:
1 2 3 | var elements = document.querySelectorAll("p"); // NodeList var arrayElements = [].slice.call(elements); // Now the NodeList is an array var arrayElements = Array.from(elements); // This is another way of converting NodeList to Array |
数组元素的洗牌
对于数组元素的洗牌,不需要使用任何外部的库,比如Lodash,只要这样做:1 2 | var list = [1,2,3]; console.log(list.sort(function() { Math.random() - 0.5 })); // [2,1,3] |
总结
现在你学会了些有用的JavaScript小技巧。希望这些小技巧能在工作中帮助你解决一些麻烦,或者说这篇文章对你有所帮助。如果你有一些优秀的JavaScript小技巧,欢迎在评论中与我们一起分享。相关文章推荐
- JavaScript--表单的序列化
- C# 序列化JavaScriptSerializer
- JavaScript中用let语句声明作用域的用法讲解
- js代码定时执行一个方法,延迟一定时间后执行一个函数
- 如何用JavaScript实现动态修改CSS样式表
- JavaScript原型(prototype)小记
- JavaScript中的跨浏览器事件操作的基本方法整理
- 用JavaScript动态建立或增加CSS样式表的实现方法
- <Js>数据类型
- js抛物线
- Web前端程序员推荐7个实用的JavaScript工具
- js判断单选按钮是否被选中
- NW.js & Electron Compared (2016 Edition)
- 详解JavaScript中的事件流和事件处理程序
- json一些特点
- js跨域请求
- js简单分页,可用
- JavaScript中的Object对象学习教程
- chart.js 入门&&highcharts 入门(推荐使用highcharts)
- Js中动态创建Json,动态为Json添加属性、属性值