所以我有一些JavaScript打开一个没有目标URL的新窗口。然后,我想将该窗口的HTML内容设置为变量的内容,这是一个有效的HTML长字符串。设置window.open()的HTML在Internet Explorer中产生奇怪的样式问题
var myHtmlHead = "
var myHtmlBody = "
var myWindow= window.open("", "MyWindow","height=500,width=500");
myWindow.document.head.innerHTML = myHtmlHead;
myWindow.document.body.innerHTML = myHtmlBody;
为了便于阅读,我剪掉了内容。问题是,虽然这在Chrome和Firefox中完美运行,但IE引发了一些奇怪的样式问题; CSS加载,但所有的DIV都居中并重叠,只要我调整窗口大小即使是一个像素,它也会自行修正。我认为这是由于我在加载窗口后加载CSS,并且在窗口需要重绘之前没有正确应用它。
有没有办法解决这个问题,或者从父页面的JS以编程方式触发重绘?
编辑:IE版本是11.0.9600,但它似乎与Chrome 49工作正常,例如。
+0
你应该清楚地描述浏览器关于这个问题的版本。 –
+0
为什么你分配给head和body元素的innerHTML的代码包含head和body的标签_again_? –
+0
@CBroe是的,为了清晰起见,编写示例时这是一个错误。头部和身体不包括第二组标签。 –