Apabila memfaktorkan semula beberapa kod JavaScript lama, anda mungkin menghadapi banyak manipulasi DOM. Berikut ialah contoh cara menggunakan JavaScript tulen untuk melaksanakan manipulasi DOM:
var d = document; var odv = d.createElement("div"); odv.style.display = "none"; this.OuterDiv = odv; var t = d.createElement("table"); t.cellSpacing = 0; t.className = "text"; odv.appendChild(t);
Untuk melihat sama ada terdapat cara yang lebih baik untuk menyelesaikan tugasan ini menggunakan jQuery, anda boleh mencuba:
var odv = $.create("div"); $.append(odv); // 其他更多操作
Tetapi anda mungkin tidak pasti sama ada ini pendekatan yang lebih baik.
Penyelesaian sehenti
Berikut ialah contoh penggunaan jQuery untuk memudahkan operasi di atas menjadi "satu baris" kod:
this.$OuterDiv = $('<div></div>') .hide() .append($('<table></table>') .attr({ cellSpacing : 0 }) .addClass("text") ) ;
Dalam contoh ini, kami mencipta elemen baharu sebagai rentetan HTML dan menyerahkannya kepada fungsi $(). Kami kemudian menetapkan gaya paparan kepada "tiada" dan menambah elemen jadual dengan cellSpacing 0 dan kelas "teks".
Pendekatan ini menggabungkan kuasa jQuery dengan kesederhanaan rentetan HTML, membolehkan anda melakukan manipulasi DOM yang kompleks dengan satu baris kod.
Pertimbangan prestasi
Tanda aras terkini pada jQuery 1.4, 1.5, 1.6 dan 1.7.2 menunjukkan bahawa mencipta elemen menggunakan kaedah document.createElement() adalah lebih pantas daripada menggunakan kaedah Kaedah Jquery Lebih Cepat. Walau bagaimanapun, perbezaan ini sangat kecil dan tidak ketara untuk kebanyakan aplikasi.
Oleh itu, kesederhanaan kod dan potensi peningkatan prestasi boleh ditimbang antara satu sama lain apabila memilih pendekatan yang hendak digunakan. Untuk aplikasi yang memerlukan manipulasi DOM pantas, document.createElement() boleh digunakan. Untuk aplikasi yang kebolehbacaan dan kesederhanaan adalah lebih penting, pendekatan jQuery kekal sebagai pilihan yang baik.
Atas ialah kandungan terperinci Adakah Terdapat jQuery yang Setara dengan `document.createElement()` untuk Manipulasi DOM yang Cekap?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!