重現如下:
復制代碼 代碼如下:
<!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中有點特殊。
請按下面步驟依次操作。
Firefox中打開該html默認輸出了空字符串
data:image/s3,"s3://crabby-images/92d64/92d64013333ca4f793f039c34e12a719b6842ff2" alt=""
控制台中執行changeDesignMode方法,再執行prif方法,這時輸出的innerHTML為“<br>”,如下
data:image/s3,"s3://crabby-images/6feb7/6feb756ffd62b01f9f6f140c4f42371d423f0b66" alt=""
Chrome/Safari/Opera輸出的仍然是空字符串。