jq给标签动态添加id_jquery怎样给动态生成的标签绑定事件

这次给大家带来jquery怎样给动态生成的标签绑定事件,jquery给动态生成的标签绑定事件的注意事项有哪些,下面就是实战案例,一起来看一下。

经常遇到给动态生成的标签绑定事件不好用,自己简单测试总结了下,结论如下了:

生成a标签

$(function(){

$('#btn').bind('click', function(event) {

/* 在添加标签的同时给添加的标签绑定点击事件 */

$("

Hello").appendTo("#d2");

});

///bind方法对于动态添加的标签不好使,只对已经存在的静态标签好用

$('li').bind('click', function(event) {

alert("haha"); ///根本不会触发这个方法

});

})

点击按钮,就会在d2中添加一个li标签,这个可以。

但是,如果这样在初始化时,用bind方法给将来要动态生成的li标签绑定方法是无效的,点击生成的li标签,没有任何反应。

因为bind方法只能给在执行它时已经存在的静态标签jq对象绑定事件,对未来动态添加的标签是无效的。

这时,可以有几种方法来解决这个问题:

方法一:

动态生成a标签

$(function() {

///点击按钮,给d2动态添加标签

$('#btn').bind('click', function() {

/* 在添加标签的同时给添加的标签绑定点击事件 */

$("

Hello").appendTo("#d2");

});

})

function show() {

alert($(this).text());///这样打印出的是空的,没有任何东西,但是方法是会触发的(不能这样打印自己)

alert("哈哈");

}

这种方法是在动态拼接时就拼接好js原生的要触发的事件,然后把事件方法定义在script标签中。这种方法可以触发li的点击事件。但是如果要用alert($(this).text())这种打印标签自己本身信息的东西的方法,是没有任何结果显示的。这个即使是静态的标签打印自己也是不会有显示的。

要解决这个问题,可以用下面两种方法。

方法二:

生成a标签

$(function(){

$('#btn').bind('click', function(event) {

/* 在添加标签的同时给添加的标签绑定点击事件 */

$("

Hello").appendTo("#d2").bind('click', function() {

/* 显示标签的内容 */

alert($(this).text()); ///这种方式也可以正常打印出 hello

});

});

})

这种方式是可以解决上面问题的。虽然它用的也是bind方法,但是注意,它是先有目的标签对象然后才调用的bind方法,所以也是好用的。而且它居然可以正常打印自己的信息,非常厉害。

方法三:

测试静态标签的绑定方法

动态生成a标签的位置

$(function(){

$('#btn').bind('click', function() {

/* 在添加标签的同时给添加的标签绑定点击事件 */

$("

Hello").appendTo("#d2");

});

///bind方法对于动态添加的标签不好使,只对已经存在的静态标签好用

///用live方法才好用

$('li').live('click', function() {

alert($(this).text());///注意,用live还可以这样写,结果是正常的

alert("haha");

});

///通过 live() 方法附加的事件处理程序适用于匹配选择器的当前及未来的元素(比如由脚本创建的新元素)

$('#d1').live('click', function() {///对于静态和动态创建的标签都好使

alert($(this).text());///注意,用live还可以这样写,结果是正常的.这是非常重要的

alert("haha");

});

})

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

表情包
插入表情
评论将由博主筛选后显示,对所有人可见 | 还能输入1000个字符
相关推荐
©️2020 CSDN 皮肤主题: 1024 设计师:白松林 返回首页