Apakah Kaedah Optimum untuk Melumpuhkan dan Mendayakan Elemen dengan jQuery: prop() vs. attr() untuk Atribut Boolean?

Susan Sarandon
Lepaskan: 2024-10-19 19:12:30
asal
707 orang telah melayarinya

What's the Optimal Method for Disabling and Enabling Elements with jQuery: prop() vs. attr() for Boolean Attributes?

Cara Melumpuhkan dan Mendayakan Elemen dengan Berkesan menggunakan jQuery: Memahami Perbezaan Antara attr() dan prop()

Masalah:

Anda cuba melumpuhkan input pada mulanya dan kemudian mendayakannya apabila pautan diklik, tetapi penyelesaian jQuery semasa anda tidak berfungsi.

HTML:

<code class="html"><input type="text" disabled="disabled" class="inputDisabled" value=""></code>
Salin selepas log masuk

jQuery:

<code class="javascript">$("#edit").click(function(event){
   event.preventDefault();
   $('.inputDisabled').removeAttr("disabled")
});</code>
Salin selepas log masuk

Punca:

Anda menggunakan removeAttr() untuk mengalih keluar atribut "dilumpuhkan", tetapi pendekatan ini mempunyai had, terutamanya dengan atribut boolean seperti "dilumpuhkan."

Penyelesaian: Menggunakan prop() dan bukannya attr()

Untuk atribut boolean, adalah disyorkan untuk menggunakan kaedah prop() dan bukannya attr(). Kaedah ini secara eksplisit mengubah suai nilai sifat asas elemen, yang lebih cekap dan sesuai untuk atribut boolean.

JQuery yang dikemas kini:

<code class="javascript">$("#edit").click(function(event){
   event.preventDefault();
   $('.inputDisabled').prop("disabled", false); // Element(s) are now enabled.
});</code>
Salin selepas log masuk

Mengapa prop() atas attr() untuk Atribut Boolean?

  • Ketekalan: prop() secara konsisten menetapkan nilai sifat, manakala attr() boleh membawa kepada tingkah laku yang tidak dijangka dalam beberapa situasi.
  • Ketepatan: prop() mendapatkan semula dan menetapkan nilai harta sebenar, manakala attr() mungkin mengembalikan atau menetapkan nilai yang berbeza berdasarkan atribut.
  • Kecekapan: prop() lebih cekap untuk atribut boolean, kerana ia secara langsung mengubah suai sifat tanpa melibatkan atribut.

Nota: Dalam versi jQuery sebelumnya kepada 3.0, removeAttr() pada atribut boolean juga akan menetapkan sifat yang sepadan kepada false. Tingkah laku ini telah ditamatkan dalam versi kemudian, yang menonjolkan kepentingan menggunakan prop() untuk atribut boolean.

Atas ialah kandungan terperinci Apakah Kaedah Optimum untuk Melumpuhkan dan Mendayakan Elemen dengan jQuery: prop() vs. attr() untuk Atribut Boolean?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!