开发跨浏览器JavaScript

翻译|其它|编辑:郝浩|2007-08-14 10:15:37.000|阅读 1116 次

概述:

# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>

1. 通过 JavaScript 设置元素的样式 2. 设置元素的 class 属性 3. 创建输入元素 4. 向元素增加事件处理

1. 通过JavaScript设置元素的样式

通过元素(Element) setAttribute()方法设置 style 属性:

var testdiv = document.getElementById("testdiv");
testdiv.setAttribute("style", "font-size:34px;color:red;");

除了 IE(Microsoft Internet Explorer),这种方法在当前其它浏览器上都行得通。为了照顾 IE,我们可以使用设置不标准的属性---元素 style 对象的 cssText 属性。尽管这个属性不是标准的,但得到了广泛的支持(除了Opera)

var testdiv = document.getElementById("testdiv");
testdiv.style.cssText = "font-size:34px;color:red;";
  • Firefox 等浏览器:运行代码,在下面的测试区域查看效果。
  • Firefox 等浏览器 IE 浏览器: ,在下面的测试区域查看效果。

2. 设置元素的 class 属性

使用 Firefox Safari 之类的浏览器,可以通过元素(Element) setAttribute()方法设置 class 属性:

var testdiv = document.getElementById("testdiv");
testdiv.setAttribute("class", "HeaderBar");

为了照顾 IE 这个异类,它只认识 className 属性---IE className = class,其它大多数浏览器都忽略 className 属性。你可以这样做:

var testdiv = document.getElementById("testdiv");
testdiv.setAttribute("class", "HeaderBar");
testdiv.setAttribute("className", "HeaderBar");
  • Firefox 等浏览器:运行代码,在下面的测试区域查看效果。
  • Firefox 等浏览器 IE 浏览器:运行代码,在下面的测试区域查看效果。

 

这里是测试用的区域:Hello world!

上面的代码已经在 Mozilla Firefox 1.5.0.2Opera 8.54Konqueror 3.5.2测试通过。

3. 创建输入元素

注意 document.createElement()<Element>.setAttribute()方法的顺序:

var button = document.createElement("input");
button.setAttribute("type", "submit");
var testdiv = document.getElementById("testdiv").appendChild(button);
  • Firefox 等浏览器和 IE 浏览器:运行代码,在测试区域查看效果。

4. 向元素增加事件处理

标准的做法是:

var testdiv = document.getElementById("testdiv");
testdiv.setAttribute("onclick", "doFoo();");

除了 IE,上面的代码在所有的当前浏览器中都能工作。在 IE 中必须使用点词法来引用所需的事件处理程序:

var testdiv = document.getElementById("testdiv");
testdiv.onclick = function(){doFoo();};

标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com

文章转载自:csdn

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP