js CSS的 float class宽高赋值不兼容处理方法(ie7,ie8,firefox)

  次阅读 来源:互联网(转载协议) 2016-03-25 15:56 我要评论(0)

css的"float"属性

【分析说明】网页特效访问一个给定css 值的最基本句法是:object.style.property,但部分css属性跟网页特效中的保留字命名相同,如"float","for","class"等,不同浏览器写法不同。

在ie中这样写:

document.getelementbyid("header").style.stylefloat = "left";

在firefox中这样写:

document.getelementbyid("header").style.cssfloat = "left";

【兼容处理】在写之前加一个判断,判断浏览器是否是ie:

if(document.all){document.getelementbyid("header").style.stylefloat = "left";}else{document.getelementbyid("header").style.cssfloat = "left";}

2. 访问<label>标签中的"for"

【分析说明】和"float"属性一样,同样需要使用不现的句法区分来访问<label>标签中的"for"。

在ie中这样写:

var myobject = document.getelementbyid("mylabel");var myattribute = myobject.getattribute("htmlfor");

在firefox中这样写:

var myobject = document.getelementbyid("mylabel");var myattribute = myobject.getattribute("for");

【兼容处理】解决的方法也是先 判断浏览器类型。

3. 访问和设置class属性

【分析说明】同样由于class是javascript保留字的原因,这两种浏览器使用不同的 javascript 方法来获取这个属性。

ie8.0之前的所有ie版本的写法:

var myobject = document.getelementbyid("header");var myattribute = myobject.getattribute("classname");

适用于ie8.0 以及 firefox的写法:

var myobject = document.getelementbyid("header");var myattribute = myobject.getattribute("class");

另外,在使用setattribute()设置class属性的时候,两种浏览器也存在同样的差异。

setattribute("classname",value);

这种写法适用于ie8.0之前的所有ie版本,注意:ie8.0也不支持"classname"属性了。

setattribute("class",value);适用于ie8.0 以及 firefox。

【兼容处理】

方法一,两种都写上:

var myobject = document.getelementbyid("header");myobject.setattribute("class","classvalue");myobject.setattribute("classname","classvalue"); //设置header的class为classvalue

方法二,ie和ff都支持object.classname,所以可以这样写:

var myobject = document.getelementbyid("header");myobject.classname="classvalue";//设置header的class为classvalue

方法三,先判断浏览器类型,再根据浏览器类型采用对应的写法。

4. 对象宽高赋值问题

【分析说明】firefox中类似 obj.style.height = imgobj.height 的语句无效。

【兼容处理】统一使用 obj.style.height = imgobj.height + 'px';

>

本站部分文章来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • 品友互动为Digital Travel APAC2018 唯一受邀中国AI企业

    品友互动为Digital Travel APAC2018 唯一受邀中国AI企业

  • 第一批国家重点研发计划公布,旷视科技开启“五年行动”

    第一批国家重点研发计划公布,旷视科技开启“五年行动”

  • 让AI触手可及  Qualcomm携手创通联达推出全新终端侧AI开发套件

    让AI触手可及 Qualcomm携手创通联达推出全新终端侧AI开发套件

  • 长虹新款智能语音空调,告诉你空调也能玩Siri

    长虹新款智能语音空调,告诉你空调也能玩Siri

网友点评网友点评
阅读推荐阅读推荐

据外媒报道,STEER打造了首款完全自动驾驶停车技术,旨在使常规车辆转变为无人驾驶车辆。STEER的首款技术应用是4级自动驾驶及网络安全停车...

近日,美国软性机器抓手制造商 Soft Robotics 宣布,获得 2000 万美元的融资,本轮投资者包括 Scale Venture Partners,Calibrate Ventures...

据外媒报道,加州车管局发布了《2017自动驾驶脱离报告(California Autonomous Vehicle Disengagement Reports)》,其中谈及了脱离的具体...

用人机语音交互,来解决智能家居适老的问题;通过家庭门禁与安防套件、空气净化套件、可燃气体与有害气体监控套件等相互联动,在不同生活情...