Rumah > hujung hadapan web > tutorial js > Mengapa kaedah JavaScript `indexOf()` saya gagal dalam IE8, dan bagaimana saya boleh membetulkannya?

Mengapa kaedah JavaScript `indexOf()` saya gagal dalam IE8, dan bagaimana saya boleh membetulkannya?

DDD
Lepaskan: 2024-12-01 04:28:10
asal
455 orang telah melayarinya

Why is my JavaScript `indexOf()` method failing in IE8, and how can I fix it?

Kaedah Array indexOf() yang hilang dalam IE8

Dalam kod yang disediakan, kaedah indexOf() digunakan pada tatasusunan dalam fungsi CheckMe(). Walaupun fungsi ini berfungsi dengan sempurna dalam Opera, Firefox dan Chrome, ia menghadapi ralat dalam IE8 pada baris if ( allowed.indexOf(ext[1]) == -1). Isu ini timbul kerana IE8 tidak menyokong fungsi indexOf() untuk tatasusunan secara asli.

Untuk menyelesaikan isu ini, anda boleh memasukkan polyfill yang menambahkan kaedah indexOf() pada objek Array. Berikut ialah contoh:

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;
  };
}
Salin selepas log masuk

Pelaksanaan indexOf() ini berdasarkan versi daripada MDN dan serasi dengan Firefox dan SpiderMonkey. Ia akan menambah kaedah indexOf() pada objek Array dalam IE8 atau mana-mana penyemak imbas lain yang tidak menyokongnya secara asli.

Dengan memasukkan polyfill ini, anda boleh memastikan bahawa kod anda akan berfungsi seperti yang dimaksudkan walaupun dalam pelayar lama seperti IE8 yang tidak mempunyai kaedah indexOf().

Atas ialah kandungan terperinci Mengapa kaedah JavaScript `indexOf()` saya gagal dalam IE8, dan bagaimana saya boleh membetulkannya?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan