预编译--作用域链--闭包--防抖--节流

js会产生作用域链,是因为有预编译的存在,所以作用域链就是AO和GO的集合。

因为有作用域链,所以可以产生闭包。

产生闭包之后,就能实现变量共享,通过return的方式,加上setTimeout函数就可以实现防抖和节流了。

防抖时重新触发延时,就是定时器的运用,事件在一段时间内连续触发它就不会执行,而是会重新延时,所以每次执行函数都要有时间变量来判断,这个时间变量就用闭包来实现共享的。

节流就是一段时间内只执行一次。比如实现百度的搜索提示联想词功能,只有你不输入内容之后,并且过一段时间才会进行数据异步交互。

防抖就是你不动之后才会执行(如计算可视视图),节流就是动的再多也只执行一次(如视图中资源加载)。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值