<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>函数节流</title>
<style>
div{
font-size:40px;
color:red;
text-align: center;
}
</style>
</head>
<body>
<div>0</div>
<script>
var a=0;
var oDiv=document.getElementsByTagName('div')[0];
var throttle=function(fn,wait){
var startTime=new Date();
return function(){
var arg=arguments;
var context=this;
var curTime=new Date();
// 如果达到了规定的触发时间间隔,触发 handler
var remaing=wait-(curTime-startTime)
if(remaing<=0||remaing>wait){//按理说remaing足够证明已经到了时间间隔,但是为了防止客户端修改了时间所以加个条件(为什么这么加我也不懂)
fn.apply(context,arg);
startTime=curTime;
}
};
};
window.onmousemove=throttle(function(){
a++;
oDiv.innerText=a+"";
},2000);
</script>
</body>
</html>
function throttle(fun, delay, time) {
var timeout,
startTime = new Date();
return function() {
var context = this,
args = arguments,
curTime = new Date();
clearTimeout(timeout);
// 如果达到了规定的触发时间间隔,触发 handler
if (curTime - startTime >= time) {
fun.apply(context, args);
startTime = curTime;
// 没达到触发间隔,重新设定定时器
} else {
timeout = setTimeout(function(){
fun.apply(context, args);
}, delay);
}
};
};
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>函数节流</title>
<style>
div{
font-size:40px;
color:red;
text-align: center;
}
</style>
</head>
<body>
<div>0</div>
<script>
var a=0;
var oDiv=document.getElementsByTagName('div')[0];
var throttle=function(fn,time){
var timer=null;
return function(){
var arg=arguments;
var context=this;
if(timer){
return false;
}
else{
timer=setTimeout(function(){
clearTimeout(timer);
timer=null;
fn.apply(context,arg);
},time);
}
};
};
window.onmousemove=throttle(function(){
a++;
oDiv.innerText=a+"";
},2000);
</script>
</body>
</html>
机械节能产品生产企业官网模板...
大气智能家居家具装修装饰类企业通用网站模板...
礼品公司网站模板
宽屏简约大气婚纱摄影影楼模板...
蓝白WAP手机综合医院类整站源码(独立后台)...苏ICP备2024110244号-2 苏公网安备32050702011978号 增值电信业务经营许可证编号:苏B2-20251499 | Copyright 2018 - 2025 源码网商城 (www.ymwmall.com) 版权所有