JS如何充分“压榨”浏览器

不同浏览器厂商实现的 JS 标准有所不同,这意味着 window 对象和可用的 api 也有所不同,希望不久的将来,所有浏览器都能实现统一的 JS 标准。

自己写 api 是很耗费时间跟精力的,而且变相增加了传输文件的大小,充分利用浏览器里 JS 解释器内置的方法,可以使我们的工作效率大大提升,以下均在 chrome 浏览器实现:

 

  1.判断一个值类型变量所属的类:

    var n = NaN

    console.log( n.__proto__.constructor.name ) // Number

    console.log( Object.prototype.toString.call( n ).slice(8 , -1) === n.__proto__.constructor.name ) // true

    注:第一种方式如果写成函数 api ,需要考虑实参是 null 和 undefined 的两种情况,第二种方式还可获取对象的类属性。

 

  2.求数组最大值:

    var arr = [ 1,2,3 ]

    console.log( Math.max.apply( Math, arr ) ) // 3

 

  3.字符串可用的数组 api :

    所有不改变原数组的数组 api 对于字符串来说都是可用的,反之则不可用,这是由字符串属不可变数据类型这一特点决定。

    可用的 api 有 .slice(); .concat(); .every(); .some(); .forEach(); .map(); 等,不可用的有 .pop(); .push(); .splice();等。

 

  4.快速复制数组:

    通过 .concat(); .slice(); 实现浅复制。

    注:深度复制需要用 JSON.parse(JSON.stringify)。

    

posted on 2019-02-25 11:12  Lowki  阅读(170)  评论(0编辑  收藏  举报