1. 程式人生 > >common.js

common.js

content 頁面滾動 scrolltop 兼容性 ror etsec 下一個 ear ons

function my$(id) {
  return document.getElementById(id);
}

// 處理瀏覽器兼容性
// 獲取第一個子元素
function getFirstElementChild(element) {
    var node, nodes = element.childNodes, i = 0;
    while (node = nodes[i++]) {
        if (node.nodeType === 1) {
            return node;
        }
    }
    return null;
}

// 處理瀏覽器兼容性
// 獲取下一個兄弟元素
 function getNextElementSibling(element) {
    var el = element;
    while (el = el.nextSibling) {
      if (el.nodeType === 1) {
          return el;
      }
    }
    return null;
  }


// 處理innerText和textContent的兼容性問題
// 設置標簽之間的內容
function setInnerText(element, content) {
  // 判斷當前瀏覽器是否支持 innerText
  if (typeof element.innerText === ‘string‘) {
    element.innerText = content;
  } else {
    element.textContent = content;
  }
}

// 處理註冊事件的兼容性問題
// eventName, 不帶on,  click  mouseover  mouseout
function addEventListener(element, eventName, fn) {
  // 判斷當前瀏覽器是否支持addEventListener 方法
  if (element.addEventListener) {
    element.addEventListener(eventName, fn);  // 第三個參數 默認是false
  } else if (element.attachEvent) {
    element.attachEvent(‘on‘ + eventName, fn);
  } else {
    // 相當於 element.onclick = fn;
    element[‘on‘ + eventName] = fn;
  }
}

// 處理移除事件的兼容性處理
function removeEventListener(element, eventName, fn) {
  if (element.removeEventListener) {
    element.removeEventListener(eventName, fn);
  } else if (element.detachEvent) {
    element.detachEvent(‘on‘ + eventName, fn);
  } else {
    element[‘on‘ + eventName] = null;
  }
}

// 獲取頁面滾動距離的瀏覽器兼容性問題
// 獲取頁面滾動出去的距離
function getScroll() {
  var scrollLeft = document.body.scrollLeft || document.documentElement.scrollLeft;
  var scrollTop = document.body.scrollTop || document.documentElement.scrollTop;
  return {
    scrollLeft: scrollLeft,
    scrollTop: scrollTop
  }
}

// 獲取鼠標在頁面的位置,處理瀏覽器兼容性
function getPage(e) {
  var pageX = e.pageX || e.clientX + getScroll().scrollLeft;
  var pageY = e.pageY || e.clientY + getScroll().scrollTop;
  return {
    pageX: pageX,
    pageY: pageY
  }
}


//格式化日期對象,返回yyyy-MM-dd HH:mm:ss的形式
function formatDate(date) {
  // 判斷參數date是否是日期對象
  // instanceof  instance 實例(對象)   of 的
  // console.log(date instanceof Date);
  if (!(date instanceof Date)) {
    console.error(‘date不是日期對象‘)
    return;
  }

  var year = date.getFullYear(),
      month = date.getMonth() + 1,
      day = date.getDate(),
      hour = date.getHours(),
      minute = date.getMinutes(),
      second = date.getSeconds();

  month = month < 10 ? ‘0‘ + month : month;
  day = day < 10 ? ‘0‘ + day : day;
  hour = hour < 10 ? ‘0‘ + hour : hour;
  minute = minute < 10 ? ‘0‘ + minute : minute;
  second = second < 10 ? ‘0‘ + second : second;

  return year + ‘-‘ + month + ‘-‘ + day + ‘ ‘ + hour + ‘:‘ + minute + ‘:‘ + second;
}

// 獲取兩個日期的時間差
function getInterval(start, end) {
  // 兩個日期對象,相差的毫秒數
  var interval = end - start;
  // 求 相差的天數/小時數/分鐘數/秒數
  var day, hour, minute, second;

  // 兩個日期對象,相差的秒數
  // interval = interval / 1000;
  interval /= 1000;

  day = Math.round(interval / 60 / 60 / 24);
  hour = Math.round(interval / 60 / 60 % 24);
  minute = Math.round(interval / 60 % 60);
  second = Math.round(interval % 60);

  return {
    day: day,
    hour: hour,
    minute: minute,
    second: second
  }
}

  

common.js