JS 工具函数

Posted ycherry

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS 工具函数相关的知识,希望对你有一定的参考价值。

// var tools = function() {
  function addEvent(el, type, fn) {
    if (el.addEventListener) { // 
      el.addEventListener(type, fn, false);
    } else if (el.attachEvent) {
      el.attachEvent(‘on‘ + type, fn);
    } else {
      el[‘on‘ + type] = fn;
    }
  }

  function getStyles(elem, prop) {
    if (window.getComputedStyle) {
      if (prop) {
        return parseInt(window.getComputedStyle(elem)[prop]);
      } else {
        return window.getComputedStyle;
      }
    } else if (elem.currentStyle) {
      if (prop) {
        return elem.currentStyle[prop]
      } else {
        return elem.currentStyle;
      }

    }
  }

  function getEleDocPosition(ele) {
    var parent = ele.offsetParent,
      offsetLeft = ele.offsetLeft,
      offsetTop = ele.offsetTop;
    while (parent) {
      offsetLeft += parent.offsetLeft;
      offsetTop += parent.offsetTop;
      parent = parent.offsetParent;
    }

    return {
      left: offsetLeft,
      top: offsetTop
    }
  }

  function getScrollSize() {
    if (document.body.scrollHeight) {
      return {
        width: document.body.scrollWidth,
        height: document.body.scrollHeight
      };
    } else {
      return {
        width: document.documentElement.scrollWidth,
        height: document.documentElement.scrollHeight
      }
    }
  }

  function getViewportSize() {
    if (window.innerWidth) {
      return {
        width: window.innerWidth,
        height: window.innerHeight
      }
    } else {
      if (document.compatMode === ‘BackCompat‘) {
        return {
          width: document.body.clientWidth,
          height: document.body.clientHeight
        }
      } else if (document.compatMode === ‘CSS1Compat‘) {
        return {
          width: document.documentElement.clientWidth,
          height: document.documentElement.clientHeight
        }
      }
    }
  }

  function getScrollOffset() {
    if (window.pageXOffset) { // w3c 规范
      return {
        left: window.pageXOffset,
        top: window.pageYOffset
      }
    } else {
      return {
        left: document.body.scrollLeft + document.documentElement.scrollLeft, //document.body.scrollLeft 和 document.documentElement.scrollLeft都是数字类型,不存在即为0
        top: document.body.scrollTop + document.documentElement.scrollTop,
      }
    }
  }

  function elemChildren(node) {
    var temp = {
      ‘length‘: 0,
      ‘push‘: Array.prototype.push,
      ‘splice‘: Array.prototype.splice
    },
        children = node.childNodes;
    for (var i = 0; i < children.length; i++) {
      var childItem = children[i];

      if (childItem.nodeType === 1) {
        // temp[temp[‘length‘]] = childItem;
        // temp[‘length‘]++;
        temp.push(childItem);
      }
    }
    return temp;
  }

  function cancelBuble(e) {
    if (e.stopPropagation) {
      e.stopPropagation();
    } else {
      e.cancelBuble = true;
    }
  }


//   return {
//     addEvent: addEvent,
//     getStyles: getStyles,
//     getEleDocPosition: getEleDocPosition,
//     getScrollWidth: getScrollWidth,
//     getViewportSize: getViewportSize,
//     getScrollOffset: getScrollOffset,
//     elemChildren: elemChildren,
//     cancelBuble: cancelBuble
//   }
// };

 

以上是关于JS 工具函数的主要内容,如果未能解决你的问题,请参考以下文章

回归 | js实用代码片段的封装与总结(持续更新中...)

vscode代码片段生成vue模板

Chrome 实用调试技巧

JS的数据类型判断函数数组对象结构处理日期转换函数,浏览器类型判断函数合集

几个关于js数组方法reduce的经典片段

web代码片段