javascript - 通过js添加的元素点击事件无法触发
PHP中文网
PHP中文网 2017-04-11 10:08:13
[JavaScript讨论组]
js添加p的语句: 
var blk_have ="

"; $("#blk").prepend(blk_have); $(".sw-off").click(function(){ $(this).toggleClass("sw-on"); }); 只截取了部分代码

但是手动在页面上这样写 却可以触发click事件.....
想问问这样为什么不会更改class?

PHP中文网
PHP中文网

认证高级PHP讲师

全部回复(4)
天蓬老师

试试这样写:

var blk_have ='<p class="sw-off"></p>';
$('#blk').prepend(blk_have);

    
$(document).on('click', '.sw-off', function(){
    $(this).toggleClass('sw-on');
});
高洛峰

动态添加的dom元素最好用事件代理来获取添加的元素,你这样写可能会失效,获取不到新添加DOM元素。建议写成,

$("#blk").on('click','.sw-off',function(){

$(this).toggleClass('sw-on');

})

大家讲道理

恐怕是因为你的 class 写得不对,按照你的写法根本没有双引号嘛

大家讲道理

一般通过js动态添加的元素,在事件触发时元素还没有添加上。在加事件时需要用到on(或live,新版本的jQuery中用‘on’代替‘live’,你可以看一下你的jQuery的版本)。如下:
$(".sw-off").on('click',function(){

$(this).toggleClass("sw-on");

})

你再试一下可不可以。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号