通过Jquery append方法添加的img元素被执行了两次onload事件

似乎是Jquery的一个Bug,因为一般来说,在任何情况下都不应该重复触发onload事件。

重现Bug的代码如下:

$(function(){ 
    $("#test").append('<img οnlοad="alert(\'hi\')" src="Image.jpg">');
})

百般百度无果,最终在StackOverFlow上找到了同样的问题:

http://stackoverflow.com/questions/10816053/jquery-img-added-through-append-triggers-onload-twice

该问题中给出的回答是Jquery在create和shift元素的时候都会导致触发onload事件。听上去并不是很科学。不过至少给出了一种可以避免Bug的写法:

$(function() {
    $("#test").append(
        $("<img>").attr({
            src: "Bachalpseeflowers.jpg",
            onload: "alert(\'hi\')"
        })
    );
});

或者,可以使用$('#test').html()方法代替append方法添加包含onload事件的图片。

转载于:https://www.cnblogs.com/justlancer/p/4253129.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值