在这篇文章中将给你们分享12个有关于JavaScript的小技巧。这些小技巧可能在你的实际工做中或许能帮助你解决一些问题。正则表达式
!!
操做符转换布尔值有时候咱们须要对一个变量查检其是否存在或者检查值是否有一个有效值,若是存在就返回true
值。为了作这样的验证,咱们可使用!!
操做符来实现是很是的方便与简单。对于变量可使用!!variable
作检测,只要变量的值为:0
、null
、" "
、undefined
或者NaN
都将返回的是false
,反之返回的是true
。好比下面的示例:数组
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
,好比下面的示例:缓存
function toNumber(strNumber) { return +strNumber; } console.log(toNumber("1234")); // 1234 console.log(toNumber("ACB")); // NaN
这个也适用于Date
,在本例中,它将返回的是时间戳数字:app
console.log(+new Date()) // 1461288164385
若是你有一段这样的代码:dom
if (conected) { login(); }
你也能够将变量简写,而且使用&&
和函数链接在一块儿,好比上面的示例,能够简写成这样:函数
conected && login();
若是一些属性或函数存在于一个对象中,你也能够这样作检测,以下面的代码所示:性能
user && user.login();
||
运算符在ES6中有默认参数这一特性。为了在老版本的浏览器中模拟这一特性,可使用||
操做符,而且将将默认值当作第二个参数传入。若是第一个参数返回的值为false
,那么第二个值将会认为是一个默认值。以下面这个示例:this
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
这个技巧很简单,这个在处理一个很大的数组循环时,对性能影响将是很是大的。基本上,你们都会写一个这样的同步迭代的数组:spa
for(var i = 0; i < array.length; i++) { console.log(array[i]); }
若是是一个小型数组,这样作很好,若是你要处理的是一个大的数组,这段代码在每次迭代都将会从新计算数组的大小,这将会致使一些延误。为了不这种现象出现,能够将array.length
作一个缓存:
var length = array.length; for(var i = 0; i < length; i++) { console.log(array[i]); }
你也能够写在这样:
for(var i = 0, length = array.length; i < length; i++) { console.log(array[i]); }
当你须要检测一些属性是否存在,避免运行未定义的函数或属性时,这个小技巧就显得颇有用。若是你打算定些一些跨兼容的浏览器代码,你也可能会用到这个小技巧。例如,你想使用document.querySelector()
来选择一个id
,而且让它能兼容IE6浏览器,可是在IE6浏览器中这个函数是不存在的,那么使用这个操做符来检测这个函数是否存在就显得很是的有用,以下面的示例:
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
的值,那么你能够获取数组的最后一个元素。如:
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
来截断数组。以下面这个示例:
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()
函数功能:
var string = "john john"; console.log(string.replace(/hn/, "ana")); // "joana john" console.log(string.replace(/hn/g, "ana")); // "joana joana"
若是你要合并两个数组,通常状况之下你都会使用Array.concat()
函数:
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)
来替代建立一个新数组。这种方法不是用来建立一个新的数组,其只是将第一个第二个数组合并在一块儿,同时减小内存的使用:
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)
来实现:
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,只要这样作:
var list = [1,2,3]; console.log(list.sort(function() { Math.random() - 0.5 })); // [2,1,3]
如今你学会了些有用的JavaScript小技巧。但愿这些小技巧能在工做中帮助你解决一些麻烦,或者说这篇文章对你有所帮助。若是你有一些优秀的JavaScript小技巧,欢迎在评论中与咱们一块儿分享。