【防抖和节流】

 1. 防抖

//原理 定时器或延时器
var content = document.getElementById("content");
        var num = 1;
         function count(){
             content.innerHTML = num++;
         }
       content.onmousemove = count;
        let times;
        content.onmousemove = function (){
            clearTimeout(times);
            let obj = times;
            times = setTimeout(()=>{
                times = null;
            },1000)
            console.log(obj);
            if(!obj){
                content.innerHTML = num++;
            }
        };


        2. 节流
      1)

  //时间戳
         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 content = document.getElementById("content");
         var num = 1;
         var time;
         content.onmousemove = function(){
             if(!time){
                 time = setTimeout(()=>{
                     time = null;
                     content.innerHTML = num++;
                 },1000)
             }
        }

数组扁平化

// 数组扁平化
		var arr = [1, 2, 3, [4, 3, [2, 7], 2], 5, [5, 9, 10], 7];
		// 最简单的方式(递归)
		function func(user){
			for(var i=0;i<user.length;i++){
				if(Array.isArray(user[i])==false){
					// arr.push(user[i]);
				}else{
					func(user[i]);
				}
			}
		}
		func(arr)
		console.log(arr);

深拷贝递归

使用递归深拷贝
		 function deepClone(obj){
		 	 var objs = Array.isArray(obj)?[]:{};
		 	 if(obj&&typeof obj==="object"){
		 		 for(key in obj){
		 			 if(obj.hasOwnProperty(key)){
		 				 if(obj[key]&&typeof obj[key]==="object"){
		 					 objs[key] = deepClone(obj[key]);
		 				 }else{
		 					objs[key] = obj[key];
		 				 }
		 			 }
		 		 }
	 	 }
		 	 return objs;
	 }


     
      
    

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值