zoukankan      html  css  js  c++  java
  • 设置iframe的document.designMode后仅Firefox中其body.innerHTML为br

    设置iframe的document.designMode为On可以让其可编辑,一般用在富文本编辑器组件中。这里仅列出各浏览器差异。重现如下:

    <!doctype html>
    <html>
    	<head>
    		<title>设置iframe的document.designMode后仅Firefox中其body.innerHTML为br</title>
    		<meta charset="utf-8">
     	</head>
     	<body>
    		<iframe frameborder="1" style="height: 330px;"></iframe>
    		<script>
    			var ifr = document.getElementsByTagName('iframe')[0];
    			var doc = ifr.contentWindow.document;
    			function prif() {
    				console.log(ifr.contentWindow.document.body.innerHTML);
    			}
    			
    			function changeDesignMode() {
    				ifr.contentWindow.document.designMode = 'On';
    			}
    			
    			prif();
    		</script>
     	</body>
    </html>

    以上代码iframe的body中没有写入任何html标记。正常情况下输出ifr.contentWindow.document.body.innerHTML应该是空字符串。但Firefox中有点特殊。

    请按下面步骤依次操作。

    1,Firefox中打开该html默认输出了空字符串

    2,控制台中执行changeDesignMode方法,再执行prif方法,这时输出的innerHTML为“<br>”,如下

    Chrome/Safari/Opera输出的仍然是空字符串。


  • 相关阅读:
    web项目的集成测试:模拟点击
    ignite通过注解配置查询
    log4j打印出线程号和方法名
    函数
    C语言函数的概念
    C语言字符串的输入输出
    C语言字符串处理函数
    C语言字符数组和字符串
    说说M451例程之PWM的寄存器讲解
    如何给地址赋值?(转)
  • 原文地址:https://www.cnblogs.com/snandy/p/2370247.html
Copyright © 2011-2022 走看看