Rumah >hujung hadapan web >tutorial js >Mengapa Pembuangan Elemen JavaScript Sangat Rumit, dan Bagaimana Ia Boleh Dipermudahkan?

Mengapa Pembuangan Elemen JavaScript Sangat Rumit, dan Bagaimana Ia Boleh Dipermudahkan?

Susan Sarandon
Susan Sarandonasal
2024-12-10 20:21:14583semak imbas

Why is JavaScript Element Removal So Complicated, and How Can It Be Simplified?

Memudahkan Pembuangan Elemen dalam JavaScript

Kaedah JavaScript untuk mengalih keluar elemen, yang melibatkan mencari nod induk dan kemudian mengalih keluar elemen secara manual, nampaknya menyusahkan. Ini menimbulkan persoalan: mengapa JavaScript direka bentuk dengan cara ini?

Walaupun mungkin terdapat sebab teknikal, satu penyelesaian adalah untuk menambah fungsi DOM asli. Pendekatan ini tidak sesuai untuk semua kes, tetapi ia berfungsi dengan baik dalam pelayar moden.

Kaedah Polyfill

Menggunakan kod berikut, anda boleh melanjutkan prototaip Element dan NodeList untuk memasukkan kaedah alih keluar:

Element.prototype.remove = function() {
    this.parentElement.removeChild(this);
}
NodeList.prototype.remove = HTMLCollection.prototype.remove = function() {
    for(var i = this.length - 1; i >= 0; i--) {
        if(this[i] && this[i].parentElement) {
            this[i].parentElement.removeChild(this[i]);
        }
    }
}

Dengan sambungan ini, mengalih keluar elemen menjadi semudah sebagai:

document.getElementById("my-element").remove();

Atau:

document.getElementsByClassName("my-elements").remove();

Walaupun penyelesaian ini berfungsi dengan berkesan dalam pelayar moden, ia tidak menyokong Internet Explorer 7 dan ke bawah.

Penyelesaian Pelayar Moden

Nasib baik, pelayar moden (tidak termasuk IE) telah memperkenalkan fungsi node.remove(). Fungsi ini membolehkan anda mengalih keluar elemen secara langsung, tanpa memerlukan polyfill.

Untuk menggunakan node.remove():

document.getElementById("my-element").remove();

Atau:

[...document.getElementsByClassName("my-elements")].map(n => n && n.remove());

Pendekatan ini disokong dalam semua penyemak imbas utama, termasuk Chrome, Firefox, Edge dan Safari.

Atas ialah kandungan terperinci Mengapa Pembuangan Elemen JavaScript Sangat Rumit, dan Bagaimana Ia Boleh Dipermudahkan?. 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