zoukankan      html  css  js  c++  java
  • JavaScript工具函数集

    /**
    * [getQueryStringArgs 用以解析查询字符串]
    * @return {[Object]} [一个包含所有参数的对象]
    */
    function getQueryStringArgs(){
      //取得查询字符串并去掉开头的“?”
      var qs = (location.search.length > 0 ? location.search.substring(1) : ""),
      // 保存数据对象
      args = {},
      // 取得每一项
      items = qs.length ? qs.split("&") : [],
      item = null,
      name = null,
      value = null,
      // 循环中使用的变量
      i = 0,
      len = items.length;
    
      //逐个将每一项添加到args对象中
      for (i = 0; i<len; i++){
        item = items[i].split("=");
        name = decodeURIComponent(item[0]);
        value = decodeURIComponent(item[1]);
    
        if(name.length){
        args[name] = value;
        }
      }
    
      return args;
    }
    
    /**
    * [convertToArray 将NodeList转为数组]
    * @param {[Object]} nodes [一个nodelist对象]
    * @return {[Object]} [返回一个数组]
    */
    function convertToArray(nodes){
      var array = null;
      try{
        array = Array.prototype.slice.call(nodes,0);//针对非IE浏览器
      }catch(ex){
        array = new Array();
        for(var i = 0, len = nodes.length; i < len; i++){
          array.push(nodes[i]);
        }
      }
    
      return array;
    }
    
    /**
    * [outputAttributes 遍历元素中的所有属性]
    * @param {[Object]} element [一个DOM元素对象]
    * @return {[Object]} [返回一个包含属性名=“属性值”的数组]
    */
    function outputAttributes(element){
      var pairs = new Array(),
      attrName,
      attrValue,
      i,
      len;
    
      for(i = 0, len = element.attributes.length; i < len; i++){
        attrName = element.attributes[i].nodeName;
        attrValue = element.attributes[i].nodeValue;
        if(element.attributes[i].specified){//确保IE7及更早的版本中,也只会返回特定的属性
          pairs.push(attrName + "="" + attrValue + """);    
        }
      }
    
      return pairs.join(" ");
    }
    
    /**
    * [loadScript 按需动态加载script文件]
    * @param {[String]} url [JavaScript文件地址]
    */
    function loadScript(url){
      var script = document.createElement("script");
      script.type = "text/javascript";
      script.src = url;
      document.body.appendChild(script);
    }
    
    /**
    * [loadStyles 按需动态加载css文件]
    * @param {[String]} url [CSS文件地址]
    */
    function loadStyles(url){
      var link = document.createElement("link");
      link.rel = "stylesheet";
      link.type = "text/css";
      link.href = url;
      var head = document.getElementsByTagName("head")[0];
      head.appendChild(link);
    }
    
    /**
    * [EventUtil 封装跨浏览器的事件处理工具对象]
    * @type {Object}
    */
    var EventUtil = {
    /**
    * [addHandler 添加事件处理程序]
    * @param {[Object]} ele [事件绑定dom元素]
    * @param {[String]} type [事件类型]
    * @param {[Function]} handler [事件处理函数]
    */
      addHandler: function(ele,type,handler){
        if(ele.addEventListener){
          ele.addEventListener(type,handler,false);
        }else if(ele.atachEvent){
          ele.atachEvent('on'+type,handler);
        }else{
          ele['on'+type] = handler;
        }
      },
    /**
    * [getEvent 获取事件对象]
    */
      getEvent: function(event){
        return event ? event : window.event;
      },
    /**
    * [getTarget 获取事件目标]
    */
      getTarget: function(event){
        return event.target || event.srcElement;
      },
    /**
    * [preventDefault 阻止默认事件]
    */
      preventDefault: function(event){
        if(event.preventDefault){
          event.preventDefault();
        }else{
          event.returnValue = false;
        }
      },
    /**
    * [removeHandler 移除事件处理程序]
    * @param {[Object]} ele [事件绑定dom元素]
    * @param {[String]} type [事件类型]
    * @param {[Function]} handler [事件处理函数]
    */
      removeHandler: function(ele,type,handler){
        if(ele.removeEventListener){
          ele.removeEventListener(type,handler,false);
        }else if(ele.detachEvent){
          ele.detachEvent('on'+type,handler);
        }else{
          ele['on'+type] = null;
        }
      },
    /**
    * [stopPropagation 阻止事件冒泡]
    */
      stopPropagation: function(event){
        if(event.stopPropagation){
          event.stopPropagation();
        }else{
          event.cancelBubble = true;
        }
      },
    /**
    * [getRelatedTarget 当事件为mouseover和mouseout时才有值,其余事件为null]
    */
      getRelatedTarget: function(event){
        if(event.relatedTarget){
          return event.relatedTarget;
        }else if(event.toElement){
          return event.toElement; 
        }else if(event.fromElement){
          return event.fromElement;
        }else{
          return null;
        }
      },
    /**
    * [getButton DOM版鼠标事件]
    * @param {[Object]} event [事件对象]
    */
      getButton: function(event){
        if(document.implementation.hasFeature("MouseEvents","2.0")){
          return event.button;
        }else{
        switch(event.button){
          case 0:
          case 1:
          case 3:
          case 5:
          case 7:
            return 0;
          case 2:
          case 6:
            return 2;
          case 4:
            return 1;
          }
        }
      },
    /**
    * [getWheelDelta 获取鼠标滚轮增值(delta)的方法]
    */
      getWheelDelta: function(event){
        if(event.wheelDelta){
          return (client.engine.oprea && client.engine.oprea < 9.5 ?
            -event.wheelDelta : event.wheelDelta);
        }else{
          return -event.detail * 40; 
        }
      },
    /**
    * [getCharCode 获取字符编码]
    */
      getCharCode: function(event){
        if(typeof event.charCode == "number"){
          return event.charCode;
        }else{
          return event.keyCode;
        }
      },
    /**
    * [getClipboardText 剪贴板事件,获取剪切内容]
    */
      getClipboardText: function(event){
        var clipboardData = (event.clipboardData || window.clipboardData);
        return clipboardData.getData("text");
      },
    /**
    * [setClipboardText 剪贴板事件,设置剪切内容]
    */
      setClipboardText: function(event, value){
        if(event.clipboardData){
          return event.clipboardData.setData("text/plain", value);
        }else if(window.clipboardData){
          return window.clipboardData.setData("text", value);
        }
      }
    }
    
    /**
    * [serialize 表单序列化]
    * @param {[Object]} form [一个表单dom对象]
    */
    function serialize(form){
      var parts = [],
      field = null,
      i,
      len,
      j,
      optLen,
      option,
      optValue;
    
      for(i = 0, len = form.elements.length; i < len; i++){
        field = form.elements[i];
    
        switch(field.type){
          case "select-one":
          case "select-multiple":
            if(field.name.length){
              for(j = 0,optLen = field.options.length; j < optLen; j++){
                option = field.options[j];
                if(option.selected){
                  optvalue = "";
                  if(option.hasAttribute){
                    optValue = (option.hasAttribute("value") ? 
                      option.value : option.text);
                  }else{//兼容IE
                    optValue = (option.attributes["value"].specified ? 
                      option.value : option.text);
                  }
    
                  parts.push(encodeURIComponent(field.name) + "=" +
                    encodeURIComponent(optValue));
                }
              }
            }
            break;
          case undefined: //字段集
          case "file": //文件输入
          case "submit": //提交按钮
          case "reset": //重置按钮
          case "button": //自定义按钮
            break;
          case "radio": //单选按钮
          case "checkbox": //多选按钮
            if(!field.checked){
              break;
            }
          default:
            if(field.name.length){
              parts.push(encodeURIComponent(field.name) + "=" +
                encodeURIComponent(field.value));
            }
          }
        }
      return parts.join("&");
    }
    /**
    * [trim 去掉字符串中的空格]
    * @param {[String]} str [需要进行处理的字符串]
    * @param {[Number]} type [处理的类型]
    * @return {[String]} [返回去除空格之后的字符串]
    * 1:所有空格
    * 2:前后空格
    * 3:前空格
    * 4:后空格
    */
    function trim(str, type){
      switch(type){
        case 1:
          return str.replace(/s+/g,"");
        case 2:
          return str.replace(/(^s*)|(s$)/g,"");
        case 3:
          return str.replace(/(^s*)/g,"");
        case 4:
          return str.replace(/(s*$)/g,"");
        default:
          return str;
      }
    }
    /**
    * [removeRepeatArray 数组去重]
    * new Set()是ES6的用法
    */
    function removeRepeatArray(arr){
      return Array.form(new Set(arr));
    }
    /**
    * [upsetArray 数组顺序打乱]
    */
    function upsetArray(arr){
      return arr.sort(function(){
        return Math.random() - 0.5;
      })
    }
    /**
    * [MaxArray 数组最大值]
    */
    function MaxArray(arr){
      return Math.max.apply(null,arr);
    }
    /**
    * [MinArray 数组最小值]
    */
    function MinArray(arr){
      return Math.min.apply(null,arr);
    }
    
    /**
    * 这一块的封装,主要是针对数字类型的数组
    * [sumArr 数组求和]
    */
    function sumArray(arr){
      var sum=0;
      for(var i = 0, len = arr.length; i < len; i++){
        sum += arr[i];
      }
      return sum;
    }
    /**
    * [averageArr 求数组的平均值]
    */
    function averageArray(arr){
      var sum = sumArray(arr);
      var average = sum/arr.length;
      return average;
    }
    /**
    * [randomOne 数组中随机取一个元素]
    */
    function randomOne(arr) {
      return arr[Math.floor(Math.random() * arr.length)];
    }
    /**
    * [getEleCount 返回数组(字符串)一个元素出现的次数]
    * @param {[type]} obj [可以是一个字符串也可以是一个数组]
    * @param {[type]} ele [某个元素]
    * getEleCount('asd56+asdasdwqe','a')
    * //3
    * getEleCount([1,2,3,4,5,66,77,22,55,22],22)
    * //2
    */
    function getEleCount (obj, ele) {
      var num = 0;
      for (var i = 0, len = obj.length; i < len; i++) {
        if (ele == obj[i]) {
          num ++;
        }
      }
      return num;
    }
    /**
    * [getCount 返回数组(字符串)出现最多次数的元素和它出现次数]
    * @param {[type]} arr [处理的数组]
    * @param {[type]} rank,ranktype [rank->长度,默认为数组长度,ranktype,排序方式,默认降序]
    */
    function getCount(arr, rank,ranktype){
      var obj = {}, 
      i,
      len,
      k, 
      arr1 = [];
      //记录每一元素出现的次数
      for (i = 0, len = arr.length; i < len; i++) {
        k = arr[i];
        if (obj[k]) {
          obj[k]++;
        }
        else {
          obj[k] = 1;
        }
      }
      //保存结果{el-'元素',count-出现次数}
      for (var o in obj) {
        arr1.push({el: o, count: obj[o]});
      }
      //排序(降序)
      arr1.sort(function (n1, n2) {
        return n2.count - n1.count;
      });
      //如果ranktype为1,则为升序,反转数组
      if(ranktype === 1){
        arr1 = arr1.reverse();
      }
      var rank1 = rank || arr1.length;
      return arr1.slice(0,rank1);
    }
    /**
    * [getArrayNum 得到n1-n2下标的数组]
    * 不传第二个参数,默认返回从n1到数组结束的元素
    * @param {[Array]} arr [传入的数组]
    * @param {[Number]} n1 [开始的位置]
    * @param {[Number]} n2 [结束的位置]
    */
    function getArrayNum(arr,n1,n2){
      var arr1 = [],
      len = n2 || arr.length - 1;
      for(var i = n1; i <= len; i++){
        arr1.push(arr[i]);
      }
      return arr1;
    }
    /**
    * [removeArrayForValue 筛选数组]
    * //removeArrayForValue(['test','test1','test2','test','aaa'],'test','%')
    * //["aaa"] 带有'test'的都删除
    * //removeArrayForValue(['test','test1','test2','test','aaa'],'test')
    * //["test1", "test2", "aaa"] //数组元素的值全等于'test'才被删除
    * @param {[type]} arr [传入的数组]
    * @param {[type]} val [要删除的值]
    * @param {[type]} type [是不是全等于value]
    */
    function removeArrayForValue(arr,val,type){
      arr.filter(function(item){
        return type === '%' ? item.indexOf(val) !== -1 : item !== val;
      });
    }
    
    /**
    * [checkPwd 检测密码强度]
    * @param {[String]} str [要检测的密码字符串]
    */
    function checkPwd(str) {
      var nowLv = 0;
      if (str.length < 6) {
        return nowLv;
      }
      if (/[0-9]/.test(str)) {
        nowLv++;
      }
      if (/[a-z]/.test(str)) {
        nowLv++;
      }
      if (/[A-Z]/.test(str)) {
        nowLv++;
      }
      if (/[.|-|_]/.test(str)) {
        nowLv++;
      }
      return nowLv;
    }
    /**
    * [repeatStr 字符串循环复制]
    * @param {[String]} str [传入的字符串]
    * @param {[Number]} count [需要循环复制的次数]
    */
    function repeatStr(str, count) {
      var text = '';
      for (var i = 0; i < count; i++) {
        text += str;
      }
      return text;
    }
    /**
    * [changeCase 字母大小写切换]
    * 1:首字母大写 
    * 2:首页母小写
    * 3:大小写转换
    * 4:全部大写
    * 5:全部小写
    * @param {[String]} str [传入的字符串]
    * @param {[Number]} type [切换的类型]
    */
    function changeCase(str,type){
      function ToggleCase(str) {
        var itemText = ""
        str.split("").forEach(
          function (item) {
            if (/^([a-z]+)/.test(item)) {
              temText += item.toUpperCase();
            }
            else if (/^([A-Z]+)/.test(item)) {
              itemText += item.toLowerCase();
            }
            else{
              itemText += item;
            }
          });
        return itemText;
      }  
    
      switch (type) {
        case 1:
          return str.replace(/^(w)(w+)/, function (v, v1, v2) {
            return v1.toUpperCase() + v2.toLowerCase();
          });
        case 2:
          return str.replace(/^(w)(w+)/, function (v, v1, v2) {
            return v1.toLowerCase() + v2.toUpperCase();
          });
        case 3:
          return ToggleCase(str);
        case 4:
          return str.toUpperCase();
        case 5:
          return str.toLowerCase();
        default:
          return str;
        }
      }
  • 相关阅读:
    Dev:LookUpEdit的用法
    Excel:写入Excel单纯写入
    浅拷贝与深拷贝
    自行车的种类
    简单的话
    Excel:导入导出原文02
    VS2010中出现无法嵌入互操作类型
    U盘有时候不显示(win7 64位)
    Knockout学习之Single Page Application
    CSS点滴整理
  • 原文地址:https://www.cnblogs.com/zyl-Tara/p/7244084.html
Copyright © 2011-2022 走看看