zoukankan      html  css  js  c++  java
  • js 常用工具函数 节流函数 防抖函数 等

    js获取url参数

      function getQueryVariable(variable) {
            var query = window.location.search.substring(1);
            var vars = query.split("&");
            for (var i = 0; i < vars.length; i++) {
                var pair = vars[i].split("=");
                if (pair[0] == variable) {
                    return pair[1];
                }
            }
            return (false);
        }
    

    截取字符串url中的参数

    function getQueryVariable(url, variable) {
    			let index = url.indexOf("?") + 1
    			let str = url.substring(index)
    			var vars = str.split("&");
    			for (var i = 0; i < vars.length; i++) {
    				var pair = vars[i].split("=");
    				if (pair[0] == variable) {
    					return pair[1];
    				}
    			}
    			return (false);
    		}
    

    删除url中特定参数重新生成url

    function createURl(url, variable) {
        let index = url.indexOf("?") + 1
        let str = url.substring(index)
        let newUrl = url.substring(0, index)
        var vars = str.split("&");
        for (var i = 0; i < vars.length; i++) {
            var pair = vars[i].split("=");
            if (pair[0] != variable) {
                if (/=/.test(newUrl)) {
                    newUrl = newUrl + `&${vars[i]}`
                } else {
                    newUrl += vars[i]
                }
            }
        }
        return newUrl
    }
    
    

    节流函数(绑定this)

    export function throttle(callBack, time = 1000) {
    	let timer;
    	return function() {
    		if (timer) return
    		timer = setTimeout(() => {
    			timer = null;
    			callBack.apply(this)
    		}, time)
    	}
    }
    

    防抖函数(绑定this)

    export function debounce(callBack, time = 1000) {
    	let timer;
    	return function() {
    		if (timer) clearTimeout(timer)
    		timer = setTimeout(() => {
    			callBack.apply(this)
    		}, time)
    	}
    }
    

    防抖函数(绑定this,立即执行)

    function debounce(func, wait, immediate) {
    
          var timeout, result;
    
          return function () {
            var context = this;
            var args = arguments;
    
            if (timeout) clearTimeout(timeout);
            if (immediate) {
              // 如果已经执行过,不再执行
              var callNow = !timeout;
              if (callNow) result = func.apply(context, args)
              timeout = setTimeout(function () {
                timeout = null;
              }, wait)
            }
            else {
              timeout = setTimeout(function () {
                func.apply(context, args)
              }, wait);
            }
            return result;
          }
        }
    

    sass求百分比公式

    // 百分比函数
    @function percent($params, $params2) {
      @return ($params / $params2)*100%
    }
    
    // vw函数
    @function vw($size) {
      @return ($size / $baseSize * 100)+vw
    }
    
    
    

    ios 上面禁止页面缩放

    解释 为提升性能 很多浏览器将passive设置为true,这就导致preventDefault()无效
    详细解释

    window.onload = () => {
      document.addEventListener('touchstart', (event) => {
        if (event.touches.length > 1) {
           event.preventDefault();
        }
      }, { passive: false });
      
      let lastTouchEnd = 0;
      document.addEventListener('touchend', (event) => {
        const now = (new Date()).getTime();
        if (now - lastTouchEnd <= 300) {
          event.preventDefault();
        }
        lastTouchEnd = now;
      }, false);
    }
    
    
    

    微信h5网页关闭分享以及关闭当前页面

    关闭网页分享一些按钮(开发者上可能会报错,请忽略,在手机上查看功能)

    document.addEventListener("WeixinJSBridgeReady", function () {
        WeixinJSBridge.call('hideOptionMenu');
    });
    

    关闭网页

     WeixinJSBridge.call('closeWindow');
    
  • 相关阅读:
    (转)Android IPC机制详解
    (转)android 多线程
    (转)android进程间通信:使用AIDL
    (转)如何调用SQLITE工具查看数据库
    (转)Android 自动 打包
    (转)如何手动编译一个APK
    (转)编译Android源码的全过程
    Js打造层拖动实例:网站菜单拖拽移位效果
    JS鼠标悬停时动态翻滚的紫色导航条
    jQuery1.3.2竖向的伸缩菜单
  • 原文地址:https://www.cnblogs.com/shiazhen/p/12712613.html
Copyright © 2011-2022 走看看