IE与Firefox在JavaScript上的7个不同句法

精贴 置顶
2581 0

尽管那需要用长串的、沉闷的不同分支代码来应付不同浏览器的日子已经过去,偶尔还是有必要做一些简单的区分和目标检测来确保某块代码能在用户的机器上正常运行。在此个人博客中,介绍7个在IE和Firefox中不同的JavaScript句法。

1. CSS "float" 值
访问一个给定CSS 值的最基本句法是:object.style.property,使用驼峰写法来替换有连接符的值,例如,访问某个ID为"header"的

的 background-color值,我们使用如下句法:

  1. document.getElementById("header").style.backgroundColor= "#ccc"

但由于"float"这个词是一个JavaScript保留字,因此我们不能用 object.style.float来访问,这里,我们可以在两种浏览器中这么做:

在IE中这样写:

  1. document.getElementById("header").style.styleFloat = "left"

在Firefox中这样写:

  1. document.getElementById("header").style.cssFloat = "left"

2. 元素的推算样式
JavaScript可以使用object.style.property句法,方便地在外部访问和修改某个CSS样式,但其限制是这些句法只能取出已设的行内样式或者直接由JavaScript设定的样式。并不能访问某个外部的样式表。为了访问元素的"推算"样式,我们可以使用下面的代码:

在IE中这样写:

  1. var myObject = document.getElementById("header");   
  2. var myStyle = myObject.currentStyle.backgroundColor; 

在Firefox中这样写: 

  1. var myObject = document.getElementById("header");   
  2. var myComputedStyle = document.defaultView.getComputedStyle(myObject, null);   
  3. var myStyle = myComputedStyle.backgroundColor; 

3. 访问元素的"class"
像"float"一样,"class"是JavaScript的一个保留字,在这两个浏览器中我们使用如下句法来访问"class"。
在IE中这样写:

  1. var myObject = document.getElementById("header");   
  2. var myAttribute = myObject.getAttribute("className"); 

在Firefox中这样写:

  1. var myObject = document.getElementById("header");   
  2. var myAttribute = myObject.getAttribute("class"); 

This syntax would also apply using the setAttribute method.

4. 访问标签中的"for"
就第3点中所提到的,我们同样需要使用不现的句法区分来访问标签中的"for":

在IE中这样写:

  1. var myObject = document.getElementById("myLabel"
  • 没有任何评论
今日天气 ···

···

···

···

热门排行
用ASP实现网页BBS 2010-11-01
CSS cursor鼠标样式一览表 2012-06-25
.NET后台写JS代码 2011-11-03
网站地址多出jdfwkey的问题解析及... 2010-08-25
数据库xxx的日志已满,请备份该数... 2013-07-19
百度、google、Yahoo网站地图制作... 2011-01-30
<a>标签的伪类书写顺序问题... 2010-09-04
什么是长尾关键词? 2010-09-24
CEO名言 2010-08-31
Mysql 主从数据库同步 2010-09-12
博主推荐
本个人博客微信公众平台上线啦~~... 2013-10-13
饼哥网络互联上线啦~~要买域名空... 2013-09-20
网站title标题如何正确修改不会被... 2013-08-26
饼哥通讯录系统上线啦,欢迎大家... 2013-08-24
ASP .NET MYSQL 的简单分页 并不... 2013-08-19
网站有弹窗广告这样的站点,百度... 2013-08-17
做淘宝SEO优化需要注意的8大问题 2013-08-17
淘宝网怎么做SEO优化 2013-08-17
站长们要学习的“苍井空精神” 2013-08-17
苹果公司今日发布了iOS 7第五个开... 2013-08-07
随便看看
关于URL组成部分的指南 2010-09-23
电脑蓝屏故障解决方法 2011-01-27
做淘宝SEO优化需要注意的8大问题 2013-08-17
隐藏文本和链接 2010-09-21
js表单不能为空或全为空格 2010-09-12
遍历数据库中所有表的Sql语句 2010-12-06
百度为什么不收录我的站点? 2010-09-24
解决在.NET 4.0下无法发送包含尖... 2013-11-16
mysql分页limit 优化 2013-08-19
ASP.NET上传文件 2010-09-08
RSS新闻
传媒新闻
CSDN
八卦新闻
女性新闻
台湾新闻
互联网
军事-新浪博客
IT-新浪博客
汽车新闻
游戏新闻
国际新闻
国内新闻
体育新闻
我的微博
北京 上海 杭州 深圳 广州 成都