Rumah hujung hadapan web tutorial js jQuery中的.bind()、.live()和.delegate()之间区别分析_jquery

jQuery中的.bind()、.live()和.delegate()之间区别分析_jquery

May 16, 2016 pm 06:06 PM
bind live

DOM树

首先,可视化一个HMTL文档的DOM树是很有帮助的。一个简单的HTML页面看起来就像是这个样子:
jQuery中的.bind()、.live()和.delegate()之间区别分析_jquery
事件冒泡(又称事件传播)
当我们点击一个链接时,其触发了链接元素的单击事件,该事件则引发任何我们已绑定到该元素的单击事件上的函数的执行。
复制代码 代码如下:

$('a').bind('click',function(){alert('that tickles!')})

因此一个单击操作会触发alert函数的执行。
jQuery中的.bind()、.live()和.delegate()之间区别分析_jquery
click事件接着会向树的根方向传播,广播到父元素,然后接着是每个祖先元素,只要是它的某个后代元素上的单击事件被触发,事件就会传给它。
jQuery中的.bind()、.live()和.delegate()之间区别分析_jquery
在操纵DOM的语境中,document是根节点。
现在我们可以较容易地说明.bind()、.live()和.delegate()的不同之处了。
.bind()
复制代码 代码如下:
$('a').bind('click',function(){alert('That tickles!');})

这是最简单的绑定方法了。JQuery扫描文档找出所有的$(‘a')元素,并把alert函数绑定到每个元素的click事件上。
.live()
复制代码 代码如下:
$('a').live('click',function(){alert('That tickles!')})

JQuery把alert函数绑定到$(document)元素上,并使用'click'和'a'作为参数。任何时候只要有事件冒泡到document节点上,它就查看该事件是否是一个click事件,以及该事件的目标元素与'a'这一CSS选择器是否匹配,如果都是的话,则执行函数。
live方法还可以被绑定到具体的元素(或“context”)而不是document上,像这样:
复制代码 代码如下:
$('a',$('#container')[0]).live('click',function(){alert('That tickles!')})

.delegate()
复制代码 代码如下:
$('#container').delegate('a','click',function(){alert('That tickles!')})


JQuery扫描文档查找$('#container'),并使用click事件和'a'这一CSS选择器作为参数把alert函数绑定到$('#container')上。任何时候只要有事件冒泡到$('#container')上,它就查看该事件是否是click事件,以及该事件的目标元素是否与CSS选择器相匹配。如果两种检查的结果都为真的话,它就执行函数。
可以注意到,这一过程与.live()类似,但是其把处理程序绑定到具体的元素而非document这一根上。精明的JS'er们可能会做出这样的结论,即$('a').live() == $(document).delegate('a'),是这样吗?嗯,不,不完全是。
为什么.delegate()要比.live()好用
基于几个原因,人们通常更愿意选用jQuery的delegate方法而不是live方法。考虑下面的例子:
复制代码 代码如下:
$('a').live('click', function() { blah() });


$(document).delegate('a', 'click', function() { blah() });
后者实际上要快过前者,因为前者首先要扫描整个的文档查找所有的$(‘a')元素,把它们存成jQuery对象。尽管live函数仅需要把'a'作为串参数传递以用做之后的判断,但是$()函数并未“知道”被链接的方法将会是.live()。

而另一方面,delegate方法仅需要查找并存储$(document)元素。
一种寻求避开这一问题的方法是调用在$(document).ready()之外绑定的live,这样它就会立即执行。在这种方式下,其会在DOM获得填充之前运行,因此就不会查找元素或是创建jQuery对象了。
灵活性和链能力
live函数也挺令人费解的。想想看,它被链到$(‘a')对象集上,但其实际上是在$(document)对象上发生作用。由于这个原因,它能够试图以一种吓死人的方式来把方法链到自身上。实际上,我想说的是,以$.live(‘a',…)这一形式作为一种全局性的jQuery方法,live方法会更具意义一些。
仅支持CSS选择器
最后一点,live方法有一个非常大的缺点,那就是它仅能针对直接的CSS选择器做操作,这使得它变得非常的不灵活。
欲了解更多关于CSS选择器的缺点,请参阅Exploring jQuery .live() and .die()一文。
更新:感谢Hacker News上的pedalpete和后面评论中的Ellsass提醒我加入接下来的这一节内容。
为什么选择.live()或.delegate()而不是.bind()
毕竟,bind看起来似乎更加的明确和直接,难道不是吗?嗯,有两个原因让我们更愿意选择delegate或live而不是bind:
1. 为了把处理程序附加到可能还未存在于DOM中的DOM元素之上。因为bind是直接把处理程序绑定到各个元素上,它不能把处理程序绑定到还未存在于页面中的元素之上。
2. 如果你运行了$('a').bind(…),而后新的链接经由AJAX加入到了页面中,则你的bind处理程序对于这些新加入的链接来说是无效的。而另一方面live和delegate则是被绑定到另一个祖先节点上,因此其对于任何目前或是将来存在于该祖先元素之内的元素都是有效的。
3. 或者为了把处理程序附加到单个元素上或是一小组元素之上,监听后代元素上的事件而不是循环遍历并把同一个函数逐个附加到DOM中的100个元素上。把处理程序附加到一个(或是一小组)祖先元素上而不是直接把处理程序附加到页面中的所有元素上,这种做法带来了性能上的好处。
停止传播
最后一个我想做的提醒与事件传播有关。通常情况下,我们可以通过使用这样的事件方法来终止处理函数的执行:
复制代码 代码如下:

$('a').bind('click',function(e){
e.preventDefault()
e.stopPropagation()}
)

不过,当我们使用live或是delegate方法的时候,处理函数实际上并没有在运行,需要等到事件冒泡到处理程序实际绑定的元素上时函数才会运行。而到此时为止,我们的其他的来自.bind()的处理函数早已运行了。
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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Penyelesaian kepada ralat Fatal PHP: Panggilan ke fungsi undefined ldap_bind() Penyelesaian kepada ralat Fatal PHP: Panggilan ke fungsi undefined ldap_bind() Jun 22, 2023 pm 11:37 PM

Apabila membangunkan aplikasi web menggunakan PHP, kita selalunya perlu menggunakan pengesahan LDAP untuk melindungi akses aplikasi. Walau bagaimanapun, dalam beberapa kes, apabila kami cuba menggunakan fungsi LDAP PHP untuk melaksanakan pengesahan, kami mungkin menghadapi mesej ralat berikut: "PHPFatalerror:Calltoundefinedfunctionldap_bind()". Mesej ralat ini biasanya berlaku apabila aplikasi memanggil fungsi ldap_bind().

apa itu linux bind apa itu linux bind Mar 25, 2023 am 09:39 AM

Linux bind ialah perintah yang digunakan untuk memaparkan atau menetapkan kekunci papan kekunci dan fungsi yang berkaitan dengannya Anda boleh menggunakan perintah bind untuk memahami kombinasi kekunci dan fungsi yang mereka ada, dan anda juga boleh menentukan kombinasi kekunci yang akan digunakan ialah "bind [-dlv][ -f <...>][-m <...>][-q <...>]".

Bagaimana untuk membetulkan ralat log masuk Xbox 0x87dd0019 Bagaimana untuk membetulkan ralat log masuk Xbox 0x87dd0019 Mar 22, 2024 pm 02:30 PM

Artikel ini akan membimbing anda untuk membetulkan ralat log masuk Xbox 0x87dd0019, yang menyebabkan isu tamat masa sambungan apabila anda cuba menyambung ke Xbox Live atau log masuk ke Xbox One. Apakah kod ralat 0x87e00019 pada Xbox? Jika anda menemui kod ralat 0x87e00019 semasa memasang atau mengemas kini permainan pada konsol Xbox anda, ini bermakna pemacu keras Xbox anda mungkin kekurangan ruang storan atau hampir penuh. Untuk menyelesaikan masalah ini, anda perlu mengosongkan sedikit ruang storan. Pada masa yang sama, anda juga harus menyemak status perkhidmatan Xbox Live, kerana ralat ini mungkin disebabkan oleh isu pelayan Xbox. Bagaimana untuk membetulkan ralat log masuk Xbox 0x87dd0019 menggunakan petua ini

Apakah yang perlu saya lakukan jika saya tidak boleh log masuk ke xbox live di win10? Win10 tidak boleh log masuk ke xbox live solution Apakah yang perlu saya lakukan jika saya tidak boleh log masuk ke xbox live di win10? Win10 tidak boleh log masuk ke xbox live solution Feb 15, 2024 am 11:51 AM

Xbox ialah pusat perkhidmatan rangkaian Microsoft sendiri Ramai pengguna mendapati komputer Win10 mereka tidak boleh log masuk ke Xbox Live apabila bermain. Biarkan laman web ini dengan teliti memperkenalkan kepada pengguna penyelesaian kepada masalah tidak dapat log masuk ke xboxlive dalam win10. Penyelesaian kepada masalah tidak dapat log masuk ke xboxlive dalam Windows 10: 1. Buka tetingkap jalankan dengan kekunci pintasan "win+R", masukkan "services.msc", dan tekan Enter untuk membukanya. 2. Selepas memasuki antara muka tetingkap "Perkhidmatan", cari "Pengurus Pengesahan xboxlive" di sebelah kanan dan klik dua kali untuk membukanya.

Ralat 0x87e107d1 semasa memuat turun kandungan Xbox Ralat 0x87e107d1 semasa memuat turun kandungan Xbox Feb 22, 2024 am 09:50 AM

Apabila anda menemui kod ralat 0x87e107d1 semasa memuat turun kandungan Xbox pada konsol anda, anda mungkin memerlukan beberapa langkah untuk menyelesaikan isu tersebut. Biasanya, ralat ini muncul apabila pengguna cuba memuat turun kandungan ke konsol permainan Xbox mereka. Seterusnya, kami akan meneroka beberapa cara untuk menyelesaikan isu ini dan memastikan anda berjaya memuat turun kandungan yang anda perlukan. Betulkan Ralat 0x87e107d1 Semasa Memuat Turun Kandungan Xbox Jika ralat 0x87e107d1 berlaku semasa memuat turun kandungan Xbox, gunakan pembetulan berikut untuk menyelesaikan isu tersebut. Semak status perkhidmatan XboxLive Semak sambungan Internet anda Matikan dan hidupkan konsol Xbox anda sekali lagi Cuba muat turun kandungan sekali lagi Padam dan tambah profil anda Mari mulakan. 1] Semak Xbox

Pelaksanaan dan penggunaan bind dalam JS Pelaksanaan dan penggunaan bind dalam JS Feb 24, 2024 pm 01:33 PM

Pelaksanaan dan penggunaan bind dalam JS Dalam JavaScript, bind ialah kaedah fungsi yang sangat berguna. Ia boleh mencipta fungsi baharu, sambil memastikan bahawa apabila fungsi dipanggil, ia mempunyai nilai ini khusus dan boleh melepasi parameter yang ditentukan. Kaedah bind ditakrifkan seperti berikut: functionbind(fn,obj,...args){returnfunction(...args2){return

Audio Chat Parti Xbox Mengganggu atau Tidak Berfungsi [Betulkan] Audio Chat Parti Xbox Mengganggu atau Tidak Berfungsi [Betulkan] Feb 19, 2024 am 11:18 AM

Jika anda menghadapi masalah dengan audio sembang terputus atau tidak berfungsi semasa menggunakan Xbox Party, ia mungkin disebabkan oleh sambungan Internet yang tidak stabil atau kegagalan perkhidmatan Xbox Live. Artikel ini akan membantu anda menyelesaikan masalah ini dan memastikan anda boleh menjalankan sembang permainan Xbox Party dengan lancar. Betulkan audio Xbox Party Chat terputus atau tidak berfungsi Gunakan pembaikan ini untuk membaiki pemotongan audio Xbox Party Chat atau tidak berfungsi: Semak status perkhidmatan XboxLive Semak sambungan internet anda Matikan dan hidupkan konsol Xbox anda sekali lagi Semak jenis NAT anda Keluar dan sertai semula parti Tetapkan Semula Kilang konsol Xbox anda dan mari mulakan. 1] Semak status perkhidmatan XboxLive dan teruskan penyelesaian masalah

Adakah perdana bermaksud hidup? Adakah perdana bermaksud hidup? Apr 04, 2025 am 12:07 AM

"Premiere" dan "Live" mempunyai makna yang berbeza dalam pengeluaran video: "Premiere" merujuk kepada pelepasan pertama atau perdana, sementara "Live" merujuk kepada siaran langsung dalam masa nyata. 1. "Premiere" adalah paparan pertama kandungan pra-rakaman. 2. Menubuhkan perdana di Adobe Premierepro melibatkan penyuntingan, penyuntingan, dan rendering, dan kemudian menjadualkan masa perdana. 3. Gunakan skrip python untuk menjadualkan perdana video. 4. Langkah -langkah utama termasuk mengeksport tetapan, penyegerakan masa dan ujian pratonton. 5. Cabaran termasuk isu prestasi, pengurusan masa, dan keserasian platform.

See all articles