微信小程序节流怎么做的?
1.在utils.js或者其他js文件中写入
//防止多次重复点击 (函数节流)
function throttle(fn, gapTime) {
if (gapTime == null || gapTime == undefined) {
gapTime = 1000
}
let _lastTime = null
// 返回新的函数
return function (e) {
console.log(this)
let _nowTime = + new Date()
if (_nowTime - _lastTime > gapTime || !_lastTime) {
// fn.apply(this, arguments) //将this和参数传给原函数
fn(this,e) //上方法不可行的解决办法 改变this和e
_lastTime = _nowTime
}
}
}
module.exports = {
throttle: throttle
}
2.在需要使用的页面的js文件中引入
<view class="right" bindtap="to_invited">wxml文件中的代码</view>
to_invited:util.throttle(
function(e){
//在这里写你需要执行的函数,5000是自定义时间
//在这里this.setData不会生效,如果要改变data的数据可以使用this.data来改变
}
,5000),
【小程序练习题外卖】