前言

最近在学习的过程中发现了我之前未曾了解过的一些特性,发现有些很有趣并且在处理一些问题的时候可以给我一个新的思路。

这里我将这些特性介绍给大家。

4 个有趣的 JS 特性

利用 a 标签解析 URL

有的时候我们需要从一个 URL 中提取域名,查询关键字,变量参数值等,一般我们会自己去解析 URL 来获取这些内容。可是你或许不知道还有更简单的方法。

即创建一个 a 标签将需要解析的 URL 赋值给 a 的 href 属性,然后我们就能很方便的拿到这些内容。代码如下:

function parseURL(url) {    var a =  document.createElement('a');    a.href = url;    return {        host: a.hostname,        port: a.port,        query: a.search,        params: (function(){            var ret = {},                seg = a.search.replace(/^\?/,'').split('&'),                len = seg.length, i = 0, s;            for (;i<len;i++) {                if (!seg[i]) { continue; }                s = seg[i].split('=');                ret[s[0]] = s[1];            }            return ret;        })(),        hash: a.hash.replace('#','')    };}

标记语句(label)

有的时候我们会写双重 for 循环做一些数据处理,我们有的时候希望满足条件的时候就直接跳出循环。以免浪费不必要资源。

这个时候我们就可以用 label 和 continue/break 配合使用:

firstLoop: for (let i = 0; i < 3; i++) {    for (let j = 0; j < 3; j++) {      if (i === j) {         continue firstLoop; // 继续 firstLoop 循环         // break firstLoop; // 中止 firstLoop 循环      }      console.log(`i = ${i}, j = ${j}`);   }}// 输出i = 1, j = 0i = 2, j = 0i = 2, j = 1for (let i = 0; i < 3; i++) {    for (let j = 0; j < 3; j++) {      if (i === j) {         continue       }      console.log(`i = ${i}, j = ${j}`);   }}// 输出i = 0, j = 1i = 0, j = 2i = 1, j = 0i = 1, j = 2i = 2, j = 0i = 2, j = 1

相信你从上面两段代码的输出可以对标记语句有一个了解。

void 运算符

void 运算符对给定的表达式进行求值,然后返回 undefined。

由于 void 会忽略操作数的值,因此在操作数具有副作用的时候使用 void 会更加合理。

使用 void 替换 undefined

由于 undefined 并不是 JavaScript 的关键字,所以我们在赋值某个变量为 undefined 时可能会有点意想不到的结果。

function t(){    var undefined = 10;    console.log(undefined);}console.log(t()); // 所有浏览器下都是10

如上代码我们可能希望赋值为 undefined,但却得到了 10 这个莫名其妙的情况。所以我们可以使用使用 void 替换 undefined。

这也是为什么我们在很多源码中都能看到使用 void 替换 undefined。

IntersectionObserver 是什么?

IntersectionObserver 可以用来监听元素是否进入了设备的可视区域之内,而不需要频繁的计算来做这个判断。

所以我们可以用这个特性来处理曝光埋点,而不是用 getBoundingClientRect().top 这种更加损耗性能的方式来处理。

当然你也可以用这个 API 来优化滚动吸顶,代码如下:

IntersectionObserverFun: function() {    let self = this;    let ele = self.$refs.pride_tab_fixed;    if( !IntersectionObserver ){        let observer = new IntersectionObserver(function(){            let offsetTop = ele.getBoundingClientRect().top;            self.titleFixed = offsetTop < 0;        }, {            threshold: [1]        });        observer.observe(document.getElementsByClassName('title_box')[0]);    } else {        window.addEventListener('scroll', _.throttle(function(){            let offsetTop = ele.getBoundingClientRect().top;            self.titleFixed = offsetTop < 0;        }, 50));    }}, 

希望这 4 个特性可以对你有所帮助,然后点个赞在走呗。

最后

如果你想进【大前端交流群】,关注公众号点击“交流加群”添加机器人自动拉你入群。关注我第一时间接收最新干货。

©著作权归作者所有:来自51CTO博客作者mb5ff592736e0cf的原创作品,如需转载,请注明出处,否则将追究法律责任

更多相关文章

  1. 【前端词典】从 returnWeekday() 谈 if() 语句代码优化
  2. 25条很棒的Python一行代码,建议收藏!
  3. 什么,3行Python代码就能获取海量数据?
  4. NBA投篮数据可视化,4行代码就能实现!
  5. 刷爆全网的动态条形图,原来5行Python代码就能实现!
  6. 牛逼!一行代码让 pandas 的 apply 速度飙到极致!
  7. 如何实现本地代码和远程的实时同步
  8. 大赞!分享一个数据科学利器 PyCaret,几行代码搞定从数据处理到模型
  9. 当面试官要求现场手敲代码,该如何体现你对Python的编程能力?

随机推荐

  1. 如何将标记中的值传递给PHP变量?
  2. HTML语言中img标签的alt属性和title属性
  3. 使用 html5 svg 绘制图形
  4. XSL:包括根本不工作
  5. 在不可见的webbrowser对象中模拟按键C#
  6. jquery将html转换为字符串和html
  7. img在div中不按百分比调整大小
  8. 为什么代码放到DW里运行,和用记事保存为H
  9. cordova HTML5第一次尝试
  10. jQuery SerialScroll:将类添加到活动项