IE9以下版本瀏覽器不兼容JavaScript功能解決方案合集

此文是爲方便日後開發中解決兼容性問題而做的筆記,不定時更新

一、Date.now()

在不支持它的瀏覽器中,可以使用+操作符把Date對象轉換成字符串,也可以達到同樣的目的。

//取得開始時間
var start = +new Date();
//調用函數
doSomething();
//取得停止時間
var stop = +new Date(),
    result = stop - start;

二、Array.isArray()

此方法在IE8以下(含IE8)的瀏覽器不支持。可以使用以下函數替代。意思是如果瀏覽器支持Array.isArray()方法則使用新方法,不支持則使用自定義判斷的方式。

function isArray(arr) {
    return (Array.isArray ? Array.isArray(arr) : (typeof arr === 'object') && (arr instanceof Array));
}

三、indexOf()

在IE8(含)以下的IE瀏覽器不支持indexOf()方法,可以用以下函數替代。在使用indexOf方法前,執行一下下面的js, 原理就是如果發現數組沒有indexOf方法,會添加上這個方法。

//添加數組indexOf方法
if (!Array.prototype.indexOf){
  Array.prototype.indexOf = function(elt /*, from*/){
    var len = this.length >>> 0;

    var from = Number(arguments[1]) || 0;
    from = (from < 0)
         ? Math.ceil(from)
         : Math.floor(from);
    if (from < 0)
      from += len;

    for (; from < len; from++){
      if (from in this && this[from] === elt)
        return from;
    }
    return -1;
  };
}

jquery裏面也有類似工具函數(jQuery.inArray()方法)

發佈了11 篇原創文章 · 獲贊 11 · 訪問量 2萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章