解决360双核浏览器兼容模式的页⾯显⽰问题
 由于众所周知的情况,国内的主流浏览器都是双核浏览器:基于Webkit内核⽤于常⽤⽹站的⾼速浏览。基于IE的内核⽤于兼容⽹银、旧版⽹站。以360的⼏款浏览器为例,我们优先通过Webkit内核渲染主流的⽹站,只有⼩量的⽹站通过IE内核渲染,以保证页⾯兼容。在过去很长⼀段时间⾥,我们主要的控制⼿段是⼀个⼏百k⼤⼩⽹址库,⼀个通过长期⼈⼯运营收集的⽹址库。
  尽管我们努⼒通过⽤户反馈、代码标签智能判断技术提⾼浏览器的⾃动切核准确率。但是在很多情况下,我们仍然⽆法达到百份百正确。因此,我们新增加了⼀个控制⼿段:内核控制Meta标签。只要你在⾃⼰的⽹站⾥增加⼀个Meta标签,告诉360浏览器这个⽹址应该⽤哪个内核渲染,哪么360浏览器就会在读取到这个标签后,⽴即切换对应的内核。并将这个⾏为应⽤于这个⼆级域名下所有⽹址。
⽬前该功能已经在所有的360安全浏览器实现。我们也建议其它浏览器⼚商⼀起⽀持这个实现。让这个控制标签成为⾏业标准。
代码⽰例
在head标签中添加⼀⾏代码:
<html>
<head>
<meta name="renderer" content="webkit|ie-comp|ie-stand">
</head>
<body>
</body>
360漫画进入漫画模式
</html>
content的取值为webkit,ie-comp,ie-stand之⼀,区分⼤⼩写,分别代表⽤webkit内核,IE兼容内核,IE标准内核。
  若页⾯需默认⽤极速核,增加标签:<meta name="renderer" content="webkit">
  若页⾯需默认⽤ie兼容内核,增加标签:<meta name="renderer" content="ie-comp">
  若页⾯需默认⽤ie标准内核,增加标签:<meta name="renderer" content="ie-stand">
  注意:引号要英⽂状态下的,直接复制代码后看⼀下格式对不对,请⾃⾏更正。
  各渲染内核的技术细节
  内核 Webkit IE兼容 IE标准
  ⽂档模式 Chrome 21 IE6/7 IE9/IE10/IE11(取决于⽤户的IE)
  HTML5⽀持 YES NO YES
  ActiveX控件⽀持 NO YES YES
今天当我尝试⼀段js代码的时候,猜测可能360兼容模式下,ie版本不是最⾼版本,代码⽐较正,例如下⾯的代码,360浏览器下⼀定要把代码写到body标签⾥⾯。⾥⾯浏览器就不⾏
<body>
<div id="dxy"></div>
<script>
var getId=function(id){
return "string"==typeof(id)?ElementById(id):id;
}
alert("ok");
getId("dxy").innerHTML="<font color=red></font>";
</script>
</body>