防抖和节流

1.节流的两种方式

第一种

延时器
var time;
		 content.onmousemove = function(){
		if(!time){
			time = setTimeout(()=>{
				time = null;
				content.innerHTML = num++;
		},1000)
		}

第二种

时间戳
		var content = document.getElementById("content");
		var num = 1;
		var timeNew = 0;
		content.onmousemove = function(){
		var timeOld = Date.now();
		if(timeOld-timeNew>1000){
				timeNew = timeOld;
				content.innerHTML = num++;
		 	}
		 }

2.防抖的两种方式

第一种

var num = 1;
let times;
先执行
content.onmousemove = function (){
		let obj = times;
		clearTimeout(times);
		times = setTimeout(()=>{
		times = null;
		},1000)
	if(!obj){
		console.log(typeof !obj);
		content.innerHTML = num++;
			}
	};

第二种

var num = 1;
let times;
后执行
content.onmousemove = function (){
		clearTimeout(times);
		times = setTimeout(()=>{
		content.innerHTML = num++;
	},1000)
		 };

3.数组扁平化的两种方式

第一种

function func(user){
		let arr1 = [];
		user.forEach((item)=>{
		Array.isArray(item)==false?arr1.push(item):arr1 = arr1.concat(func(item));
		 	})
		arr = arr1;
		return arr;
	}
		func(arr);
		 console.log(arr);

第二种

function func(user){
		let arr1 = [];
		for(var i=0;i<user.length;i++){
		if(Array.isArray(user[i])==false){
		arr1.push(user[i]);
		}else {
		arr1 = arr1.concat(func(user[i]));
	 		}
		}
		arr = arr1;
	return arr;
		}
		func(arr);
	console.log(arr);
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值