前端常用的js技巧

web前端开发技能
前端开发技能饼图
web前端开发技能树

1. 使用!!操作符转换布尔值

有时候我们需要对一个变量查检其是否存在或者检查值是否有一个有效值,如果存在就返回 true 值。为了做这样的验证,我们可以使用!!操作符来实现是非常的方便与简单。对于变量可以使用 !!variable 做检测,只要变量的值为:0、null、” “、undefined 或者 NaN 都将返回的是 false,反之返回的是 true。比如下面的示例:

javascript 代码

function Account(cash) {
    this.cash = cash
    this.hasMoney = !!cash
}
var account = new Account(100.5)
console.log(account.cash) // 100.50
console.log(account.hasMoney) // true</p>
var emptyAccount = new Account(0)
console.log(emptyAccount.cash) // 0
console.log(emptyAccount.hasMoney) // false
在这个示例中,只要account.cash的值大于0,那么account.hasMoney返回的值就是true。

2. 使用+将字符串转换成数字

这个技巧非常有用,其非常简单,可以交字符串数据转换成数字,不过其只适合用于字符串数据,否则将返回NaN,比如下面的示例:

javascript 代码

function toNumber(strNumber) {
    return +strNumber
}
console.log(toNumber(‘1234’)) // 1234
console.log(toNumber(‘ACB’)) // NaN
这个也适用于 Date,在本例中,它将返回的是时间戳数字:

javascript 代码

console.log(+new Date()) // 1461288164385

3. 并条件符

如果你写了一段这样的代码:

javascript 代码

if (conected) login();

你也可以将变量简写,并且使用 && 和函数连接在一起,比如上面的示例,可以简写成这样:

javascript 代码

conected && login();

如果一些属性或函数存在于一个对象中,你也可以这样做检测,如下面的代码所示:

javascript 代码

user && user.login();

4. 使用||运算符

在ES6中有默认参数这一特性。为了在老版本的浏览器中模拟这一特性,可以使用||操作符,并且将将默认值当做第二个参数传入。如果第一个参数返回的值为 false,那么第二个值将会认为是一个默认值。如下面这个示例:

javascript 代码

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

5. 在循环中缓存array.length

这个技巧很简单,这个在处理一个很大的数组循环时,对性能影响将是非常大的。基本上,大家都会写一个这样的同步迭代的数组:

javascript 代码

for (var i = 0; i < array.length; i++) {
    console.log(array[i])
}
如果是一个小型数组,这样做很好,如果你要处理的是一个大的数组,这段代码在每次迭代都将会重新计算数组的大小,这将会导致一些延误。为了避免这种现象出现,可以将 array.length 做一个缓存:

javascript 代码

var length = array.length
for (var i = 0; i < length; i++) {
    console.log(array[i])
}
也可以这样写:

javascript 代码

for (var i = 0, length = array.length; i < length; i++) {
    console.log(array[i])
}

6. 检测对象中属性

当你需要检测一些属性是否存在,避免运行未定义的函数或属性时,这个小技巧就显得很有用。如果你打算定些一些跨兼容的浏览器代码,你也可能会用到这个小技巧。例如,你想使用 document.querySelector() 来选择一个 id,并且让它能兼容IE6浏览器,但是在IE6浏览器中这个函数是不存在的,那么使用这个操作符来检测这个函数是否存在就显得非常的有用,如下面的示例:

javascript 代码

if (‘querySelector’ in document) {
    document.querySelector(‘#id’)
} else {
    document.getElementById(‘id’)
}
在这个示例中,如果 document 不存在 querySelector 函数,那么就会调用 docuemnt.getElementById(“id”)。

7. 获取数组中最后一个元素

Array.prototype.slice(begin,end)用来获取begin和end之间的数组元素。如果你不设置end参数,将会将数组的默认长度值当作end值。但有些同学可能不知道这个函数还可以接受负值作为参数。如果你设置一个负值作为begin的值,那么你可以获取数组的最后一个元素。如:

javascript 代码

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]

8. 数组截断

这个小技巧主要用来锁定数组的大小,如果用于删除数组中的一些元素来说,是非常有用的。例如,你的数组有10个元素,但你只想只要前五个元素,那么你可以通过 array.length=5 来截断数组。如下这个示例:

javascript 代码

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]

9. 替换所有

String.replace() 函数允许你使用字符串或正则表达式来替换字符串,本身这个函数只替换第一次出现的字符串,不过你可以使用正则表达多中的 /g 来模拟 replaceAll() 函数功能:

javascript 代码

var string = ‘john john’
console.log(string.replace(/hn/, ‘ana’)) // “joana john”
console.log(string.replace(/hn/g, ‘ana’)) // “joana joana”

10. 合并数组

如果你要合并两个数组,一般情况之下你都会使用 Array.concat() 函数:

javascript 代码

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)来替代创建一个新数组。这种方法不是用来创建一个新的数组,其只是将第一个第二个数组合并在一起,同时减少内存的使用:

javascript 代码

var array1 = [1, 2, 3]
var array2 = [4, 5, 6]
console.log(array1.push.apply(array1, array2)) // [1,2,3,4,5,6];

11. 将NodeList转换成数组

如果你运行 document.querySelectorAll(“p”) 函数时,它可能返回DOM元素的数组,也就是NodeList对象。但这个对象不具有数组的函数功能,比如 sort()、reduce()、map()、filter() 等。为了让这些原生的数组函数功能也能用于其上面,需要将节点列表转换成数组。可以使用 .slice.call(elements) 来实现:

javascript 代码

var elements = document.querySelectorAll(‘p’) // NodeList
var arrayElements = [].slice.call(elements) // 将NodeList转化为数组
var arrayElements = Array.from(elements) // 另一种方式将NodeList转化为数组

12. 数组元素的洗牌

对于数组元素的洗牌,不需要使用任何外部的库,比如Lodash,只要这样做:

javascript 代码

var list = [1, 2, 3]
console.log(
    list.sort(function() {
        Math.random() – 0.5
    }),
) // [2,1,3]
前端开发需掌握的技能
前端开发技能标签
前端开发所需技能
» 本文来自:前端开发者 » 《前端常用的js技巧》
» 本文链接地址:https://www.rokub.com/6300.html
» 您也可以订阅本站:https://www.rokub.com
赞(0)
64K

评论 抢沙发

评论前必须登录!