• Bezakan antara atribut DOM dan atribut elemen
<img src="images/image.1.jpg" id="hibiscus" alt="Hibiscus" class="classA" />
Biasanya pembangun terbiasa memanggil id, src, alt, dll. "atribut" elemen ini. Kami memanggil ini "atribut elemen". Walau bagaimanapun, apabila menghuraikan ke dalam objek DOM, penyemak imbas sebenar akhirnya akan menghuraikan elemen teg ke dalam "objek DOM" dan menyimpan "atribut elemen" elemen sebagai "atribut DOM". Terdapat perbezaan antara keduanya.
Malah sesetengah "atribut elemen" dan "atribut DOM" mempunyai nama yang berbeza, seperti kelas atribut elemen di atas, yang sepadan dengan className selepas ditukar menjadi atribut DOM.
Perlu diingat, dalam javascript kita boleh terus mendapatkan atau menetapkan "sifat DOM":
<script type="text/javascript"> $(function() { var img1 = document.getElementById("hibiscus"); alert(img1.alt); img1.alt = "Change the alt element attribute"; alert(img1.alt); img1.className = "classB"; }) </script>
Jadi, jika anda ingin menetapkan kelas gaya CSS sesuatu elemen, anda perlu menggunakan atribut DOM "className" dan bukannya atribut elemen "class".
------------------------------------------------- -----------------------------------
•Operasi "Atribut Dom"
jQuery menyediakan fungsi each() untuk melintasi set pembungkusan jQuery, dengan penunjuk ini ialah objek DOM, jadi kita boleh menggunakan ini dengan javascript asli untuk mengendalikan atribut DOM elemen:
$("img").each(function(index) { alert("index:" + index + ", id:" + this.id + ", alt:" + this.alt); this.alt = "changed"; alert("index:" + index + ", id:" + this.id + ", alt:" + this.alt); });
•Operasi "Atribut Elemen"
Kita boleh menggunakan getAttribute dan setAttribute dalam javascript untuk mengendalikan "atribut elemen" elemen. jQuery menyediakan anda dengan attr() fungsi set pembalut, yang secara serentak boleh mengendalikan atribut semua elemen dalam set pembalut:
Walaupun kami boleh menggunakan removeAttr(name) untuk memadamkan atribut elemen, atribut DOM yang sepadan tidak akan dipadamkan dan hanya akan menjejaskan nilai atribut DOM Sebagai contoh, mengalih keluar atribut elemen baca sahaja bagi elemen input akan menyebabkan Atribut DOM yang sepadan menjadi palsu (iaitu, input menjadi boleh diedit).
• Ubah suai kelas dan gaya CSS
Jadual berikut ialah kaedah jQuery yang berkaitan dengan mengubah suai kelas CSS:
Perhatikan bahawa parameter addClass(kelas) dan removeClass(kelas) boleh dihantar dalam berbilang kelas css pada satu masa, dipisahkan dengan ruang. Parameter kaedah removeClass adalah pilihan Jika tiada parameter dimasukkan, semua kelas CSS akan dialih keluar.
Begitu juga, apabila kita ingin mengubah suai gaya CSS tertentu elemen, iaitu, mengubah suai atribut elemen "gaya", jQuery juga menyediakan kaedah yang sepadan:
• Dapatkan atribut biasa
<!doctype html> <html lang="zh"> <head> <meata charset="utf-8"/> <title>get object width</title> <script src="jquery-1.11.2.min.js"></script> <script> $(function() { alert("attr(\"width\"):" + $("#testDiv").attr("width")); //undifined alert("css(\"width\"):" + $("#testDiv").css("width")); //auto(ie6) 或 1264px(ff) alert("width():" + $("#testDiv").width()); //正确的数值 1264 alert("style.width:" + $("#testDiv")[0].style.width); //空值 }) </script> </head> <body> <div id="testDiv">test text</div> </body> </html>
Kami ingin mendapatkan lebar lapisan ujian, dan menggunakan kaedah attr untuk mendapatkan "atribut elemen" sebagai tidak ditentukan, kerana lebar tidak ditambahkan pada div. Walaupun nilai atribut gaya boleh diperoleh menggunakan kaedah css(), hasil yang dikembalikan dalam penyemak imbas berbeza adalah berbeza, manakala FF mengembalikan nilai yang betul tetapi dengan "px" di belakangnya. Jadi jQuery menyediakan kaedah width(), yang mengembalikan nilai yang betul tanpa px.
Sebagai tindak balas kepada masalah di atas, jQuery menyediakan kaedah untuk mendapatkan dan menetapkan atribut yang biasa digunakan Contohnya, width() membenarkan pengguna mendapatkan lebar elemen, manakala width(val) digunakan untuk menetapkan lebar sesuatu. unsur.
Kaedah berikut boleh digunakan untuk mendapatkan nilai atribut biasa unsur:
1. Lebar dan tinggi berkaitan Tinggi dan Lebar
OuterWidth boleh menerima parameter nilai bool untuk menunjukkan sama ada untuk mengira nilai margin.
2
Penjelasan terperinci tentang atribut dan gaya operasi jQuery di atas adalah semua kandungan yang dikongsi oleh editor saya harap ia boleh memberi anda rujukan, dan saya harap anda akan menyokong Script Home.