我在使用JQuery绑定时遇到了一些麻烦。
<iframe id="wufooFormz7x3k1" height="281" allowtransparency="true" frameborder="0" scrolling="no" style="width:100%;border:none" src="http://foo111.com"></iframe>
<script>
jQuery('#wufooFormz7x3k1').ready(function()
{
jQuery('#wufooFormz7x3k1').bind('onload', alert('hi1'));
jQuery('#wufooFormz7x3k1').bind('onload', function() { alert('hi2') });
});
</script>
第一个绑定会生成一个警报,但随后会抛出此错误,并且不会触发任何后续iframe加载的警报(这是我正在尝试检测的)。
Uncaught TypeError: Cannot read property 'handler' of undefined and won't be triggered for subsequent onloads.
第二次绑定根本不会触发。
理想情况下,我想要的是绑定iframe的onload,这样我就可以在每次重新加载iframe时生成警报。
答案 0 :(得分:10)
使用加载事件。
jQuery('#wufooFormz7x3k1').bind('load', function() { alert('hi2') });
第一次尝试发出警报,因为您正在执行警报并将警报的返回值作为函数传递,但该返回值不是函数,因此会发生错误。
此外,不需要以下内容,并且不会按照您的想法执行此操作。
jQuery('#wufooFormz7x3k1').ready(function()
忽略'#wufooFormz7x3k1'
并使用document
代替。由于脚本直接位于iframe标记之后,因此您可以省略它,因为iframe已准备就绪。