iframe的onload事件监听

简介:
iframe的onload事件监听比较麻烦,浏览器注册事件监听的方式也不一样,下面是一个通用的监听方式。
 
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" 
                "http://www.w3.org/TR/html4/loose.dtd"> 
<html> 
<head> 
        <title></title> 
</head> 
<body> 
<div id="cnt"></div> 
<input name="bt" type="button" value="设置IFrame内容" 
</body> 
</html> 
<script type='text/javascript'> 
        //添加两个 
        function doAction1() { 
                alert(" 
        } 
        function doAction2() { 
                alert(" 
        } 

        function doIt() { 

                //删除所有的ifream内容 
                var div = document.getElementById("cnt"); 
                var arrifm = div.getElementsByTagName("iframe"); 
                if (arrifm.length != 0) { 
                        var x = div.removeChild(arrifm[0]); 
                        alert("清除成功!") 
                } 

                //添加新的ifream内容 
                var iframe = document.createElement("iframe"); 
                iframe.src = "b.html"; 

                //为ifream的 
                if (iframe.attachEvent) { 
                        iframe.attachEvent(" { 
                                doAction1(); 
                                alert("Local iframe is now loaded 1."); 
                        }); 
                } else { 
                        iframe.onload = function() { 
                                this.doAction2(); 
                                alert("Local iframe is now loaded 2."); 
                        } 
                } 

                //追加ifream元素 
                div.appendChild(iframe); 
                //弹出ifream的HTML代码 
//                alert(div.innerHTML); 
        } 
</script>
 
上面的事件监听写成下面的也行:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" 
                "http://www.w3.org/TR/html4/loose.dtd"> 
<html> 
<head> 
        <title></title> 
</head> 
<body> 
<div id="cnt"></div> 
<input name="bt" type="button" value="设置IFrame内容" 
</body> 
</html> 
<script type='text/javascript'> 
        //添加两个 
        function doAction1() { 
                alert(" 
        } 
        function doAction2() { 
                alert(" 
        } 

        function doIt() { 

                //删除所有的ifream内容 
                var div = document.getElementById("cnt"); 
                var arrifm = div.getElementsByTagName("iframe"); 
                if (arrifm.length != 0) { 
                        var x = div.removeChild(arrifm[0]); 
                        alert("清除成功!") 
                } 

                //添加新的ifream内容 
                var iframe = document.createElement("iframe"); 
                iframe.src = "b.html"; 

                //为ifream的 
                if (iframe.attachEvent) { 
                        iframe.attachEvent(" doAction1); 
                } else { 
                        iframe.onload = doAction2 
                } 

                //追加ifream元素 
                div.appendChild(iframe); 
                //弹出ifream的HTML代码 
//                alert(div.innerHTML); 
        } 
</script>
 
但是下面这种方式不行:
<!DOCTYPE HTML PUBLIC  "-//W3C//DTD HTML 4.01 Transitional//EN" 
                "http://www.w3.org/TR/html4/loose.dtd"> 
<html> 
<head> 
        <title></title> 
</head> 
<body> 
<div id="cnt"></div> 
<input name="bt" type="button" value="设置IFrame内容" onclick="doIt()"
</body> 
</html> 
<script type='text/javascript'> 
        function aa() { 
                alert("aaaaaaaaa"); 
        } 
        function doIt() { 

                //删除所有的ifream内容 
                var div = document.getElementById("cnt"); 
                var arrifm = div.getElementsByTagName("iframe"); 
                if (arrifm.length != 0) { 
                        var x = div.removeChild(arrifm[0]); 
                        alert("清除成功!"
                } 

                //添加新的ifream内容 
                var iframe = document.createElement("iframe"); 
                iframe.src = "b.html"

                //添加两个 
                doIt.prototype.doAction1 = function() { 
                        alert("onload1"); 
                        bb(); 
                }; 
                doIt.prototype.doAction2 = function() { 
                        alert("onload2"); 
                        bb(); 
                }; 

                // 下面的方式不行 
                if (iframe.attachEvent) { 
                        iframe.attachEvent("onload"this.doAction1()); 
                } else { 
                        iframe.onload = this.doAction2(); 
                } 

                // 下面的方式不行 
//                if (iframe.addEventListener) { 
//                        iframe.addEventListener(' this.doAction1, false); 
//                } else if (iframe.attachEvent) { 
//                        iframe.onload = this.doAction2; 
//                } 


                //追加ifream元素 
                div.appendChild(iframe); 
                //弹出ifream的HTML代码 
                alert(div.innerHTML); 
        } 

</script>
 
注意:父窗口不能调用ifream内的js方法。


本文转自 leizhimin 51CTO博客,原文链接:http://blog.51cto.com/lavasoft/481054,如需转载请自行联系原作者
相关文章
|
8月前
|
JavaScript
事件触发、事件捕获与事件冒泡(js的问题)
事件触发、事件捕获与事件冒泡(js的问题)
42 0
|
8月前
|
JavaScript 索引
用原生js的postMessage实现iframe传值,也可以用于跨域嵌套iframe传值
用原生js的postMessage实现iframe传值,也可以用于跨域嵌套iframe传值
用原生js的postMessage实现iframe传值,也可以用于跨域嵌套iframe传值
|
7月前
|
JavaScript 开发者
jQuery能绑定事件监听吗
jQuery能绑定事件监听吗
57 0
|
8月前
|
JavaScript
|
JavaScript 容器
js中的事件冒泡与事件捕获
js中的事件冒泡与事件捕获
48 0
|
JavaScript API
js: 添加事件监听addEventListener、移除事件监听removeEventListener
js: 添加事件监听addEventListener、移除事件监听removeEventListener
145 0
|
JavaScript 前端开发
简单解析js的事件冒泡及如何取消事件冒泡
简单解析js的事件冒泡 1.什么是事件冒泡? 以click点击事件为例。假如我们有一个多层结构标签。如下图,是4个div嵌套。每个div都有点击的监听事件,分别alert(“box4”),alert(“box3”),alert(“box2”),alert(“box1”)。当我们点击最里面的div时,点击事件开始传递。出现的效果是alert(“box4”)-alert(“box3”)-alert(“box2”)-alert(“box1”)。这就是事件冒泡阶段。效果如下: 在这里插入图片描述 HTML代码: &lt;div class=&quot;box1&quot;&gt; &lt;div clas
|
缓存 JavaScript 前端开发
JavaScript 页面资源加载:onload,onerror
JavaScript 页面资源加载:onload,onerror
414 0
JavaScript 页面资源加载:onload,onerror
|
JavaScript
jquery事件对象-48
jquery事件对象-48
87 0
jquery事件对象-48
|
JavaScript
js:addEventListener与onclick同时使用
js:addEventListener与onclick同时使用
115 0