html追加没有样式,js/jquery动态添加html,样式和方法不生效的解决方案

var html = "

" +

" " +

" \n" +

" \n" +

" \n" +

" \n" +

"

";

$(this).before(html);

例1 样式

bootstrap checkbox和radio

页面上bootstrap 的样式没有生效

解决办法:

//渲染js拼接的radio,checkbox按钮

$('input[type=checkbox]').iCheck({

labelHover :false,

cursor :true,

checkboxClass :'icheckbox-blue',

increaseArea :'20%'});

//渲染js拼接的radio,checkbox按钮

$('input[type=radio]').iCheck({

labelHover :false,

cursor :true,

radioClass :'iradio-blue',

increaseArea :'20%'});

例2

点击事件

此点击事件无效

$(function() {

$(".fa-remove").click(function() {var tr = $(this).parent();

tr.remove();

})

})

原因:

因为append中的节点是在整个文档加载后才添加的,页面并不会为未来的元素初始化添加点击事件,所以使用这种方式动态添加的节点中的点击事件没有生效。

解决方案:

事件委托。给所有的类名为.div的元素添加点击事件,将指定事件绑定在document上,只要而新产生的元素符合指定的元素,就会绑定此事件 ,而且这种方法当页面需要为多个节点初始化事件的时候,就不需要一个个加onclick事件。

$(document).on("click", ".fa-remove", function() {var tr = $(this).parent();

tr.remove();

})

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值