查看文章
 
ie9 rc版软件兼容问题
2011-02-14 11:56

ie9 rc新版中javascript有了很多改变,主要是为了兼容W3C标准。
本来是好事,不过也产生了一些“副作用”:

目前有些软件(特别是ie外壳浏览器)中使用了稍复杂的js脚本来做界面或软件控制,
对于这类软件,如果使用的js太有特色,就有可能引起软件崩溃问题。

1.document.createElement函数
 在ie9 preview版或之前,可以做如下使用:
  document.createElement():默认创建XML空标签。
  document.createElement(合法的html):创建给定html元素。
 这两种使用方式在ie9 rc中不可用。
 只能用document.createElement('div')之类的表达式,并且在用outerHTML返回的标签都是小写字母。

2.原生函数赋值:
 原生的函数不允许直接附值给变量,例如:
 模仿prototype的写法:
  var $=document.getElementById;在ie9 preview及之前版本都是可以的,在ie9 rc中是不合法的,
 只能用:
  var $=function(s){return document.getElementById(s)};
 类似的“技巧”会导致问题。
3.变量定义:
 用var i;定义变量,如果为了格式对齐将语句中空格用tab代替,会发生错误。
4.dom自定义属性:
 在ie9 preview及以前版本中dom元素可直接用"="操作,如:
  var o=document.getElementById('someid');
  o.myprop='strange';
  var s=o.myprop;
 而在ie9 rc中这样的写法什么都得不到,都是浮云。

 只能用setAttribute/getAttribute来操作dom元素自定义属性。
 这可能也是ie9中js速度更快的原因之一:牺牲可用性,提高效率。
5.firstChild/lastChild/previewSibling/nextSibling/childNodes[i]:
 在ie9 preview/rc中,解析html时会经常生成些预料之外的#text元素,
 会导致用一些标准的dom操作函数得到的并非是你想要的东东,如:
  var o=document.getElementById('someid').firstChild;
  在变量o中得到的很可能是个#text,而不是你真正想要的东东。

总而言之,言而总之:
写完js后在chrome/firefox/opera中试一下,可能是个好习惯。


类别:默认分类||添加到搜藏 |分享到i贴吧|浏览(370)|评论 (0)
 
最近读者:
 
网友评论:
发表评论:
姓 名:
网址或邮箱: (选填)
内 容:
     

   
帮助中心 | 空间客服 | 投诉中心 | 空间协议
©2012 Baidu