Rumah >hujung hadapan web >tutorial js >Mengapa Acara `onclick` JS `li` Tag Saya Tidak Berfungsi dalam IE8 dan Bagaimana Saya Boleh Membetulkannya?

Mengapa Acara `onclick` JS `li` Tag Saya Tidak Berfungsi dalam IE8 dan Bagaimana Saya Boleh Membetulkannya?

Barbara Streisand
Barbara Streisandasal
2024-11-28 02:14:10350semak imbas

Why Doesn't My JS `li` Tag's `onclick` Event Work in IE8, and How Can I Fix It?

JS li Tag Onclick Event Tidak Berfungsi dalam IE8

Isu yang dilaporkan dengan acara li onclick yang gagal berfungsi dalam pelayar IE8 berpunca daripada fakta bahawa IE8 tidak menyokong kaedah addEventListener. Untuk menangani perkara ini, kita perlu menggunakan pendahulunya yang tidak standard, attachEvent.

Melaksanakan attachEvent Hook

Fungsi hookEvent berikut boleh digunakan untuk mengendalikan acara dalam kedua-dua penyemak imbas yang mematuhi standard dan pelayar yang mempunyai khusus Microsoft sebelumnya mekanisme:

var hookEvent = (function() {
    var div;

    function standardHookEvent(element, eventName, handler) {
        element.addEventListener(eventName, handler, false);
        return element;
    }

    function oldIEHookEvent(element, eventName, handler) {
        element.attachEvent("on" + eventName, function(e) {
            e = e || window.event;
            e.preventDefault = oldIEPreventDefault;
            e.stopPropagation = oldIEStopPropagation;
            handler.call(element, e);
        });
        return element;
    }

    function oldIEPreventDefault() {
        this.returnValue = false;
    }

    function oldIEStopPropagation() {
        this.cancelBubble = true;
    }

    div = document.createElement('div');
    if (div.addEventListener) {
        div = undefined;
        return standardHookEvent;
    }
    if (div.attachEvent) {
        div = undefined;
        return oldIEHookEvent;
    }
    throw "Neither modern event mechanism (addEventListener nor attachEvent) is supported by this browser.";
})();

Mengintegrasikan Cangkuk ke dalam Pengendalian Acara

Untuk menggunakan cangkuk ini dalam contoh yang disediakan, kami menggantikan baris addEventListener dengan:

hookEvent(document.getElementById("hd_vertical"), "click", function(e) {
    // Event handling code
});

Pertimbangan Tambahan

IE8 juga tidak mempunyai sokongan untuk getElementsByClassName. Untuk mengimbangi, kami boleh menggunakan querySelectorAll atau querySelector sebaliknya:

var _url = document.querySelectorAll("." + id)[1].getAttribute('href'); // Grabs the second matching element
var _url = document.querySelector("." + id).getAttribute('href'); // Grabs the first matching element

Dengan memanfaatkan fungsi hookEvent dan menangani isu keserasian penyemak imbas IE8 tambahan ini, acara li onclick kini seharusnya berfungsi seperti yang diharapkan.

Atas ialah kandungan terperinci Mengapa Acara `onclick` JS `li` Tag Saya Tidak Berfungsi dalam IE8 dan Bagaimana Saya Boleh Membetulkannya?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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