【javaScript】cssText兼容及好处(相对于element.style)

更新时间:2023-06-20 23:02:59 阅读: 评论:0

【javaScript】cssText兼容及好处(相对于element.style)
文定皇后
cssText概念和特点
1. cssText 本质是什么?
cssText 的本质就是设置 HTML 元素的 style 属性值。
2. cssText 怎么⽤?
黑人犯罪率
cssText 返回值是什么?
在某些浏览器中(⽐如 Chrome),你给他赋什么值,它就返回什么值。在 IE 中则⽐较痛苦,它会格式化输出、会把属性⼤写、会改变属性顺序、会去掉最后⼀个分号,⽐如:
font-size:13px;"; ElementById("d1").style.cssText);
在 IE 中值为:FONT-SIZE: 13px; COLOR: red
动漫可爱头像男
3. cssText的使⽤优势
⼀般情况下我们⽤js设置元素对象的样式会使⽤这样的形式:
var element= ElementById(“id”);
element.style.width=”20px”;
element.style.height=”20px”;
element.style.border=”solid 1px red”;墨鱼做法大全
Ps: 样式⼀多,代码就很多;⽽且通过JS来覆写对象的样式是⽐较典型的⼀种销毁原样式并重建的过程,这种销毁和重建,都会增加浏览器的开销。
js中有⼀个cssText的⽅法:
语法为:
obj.style.cssText=”样式”;
fridgeelement.style.cssText=”width:20px;height:20px;border:solid 1px red;”;
Ps: 这样就可以尽量避免页⾯reflow,提⾼页⾯性能。
国庆休息但是,这样会有⼀个问题,会把原有的cssText清掉,⽐如原来的style中有’display:none;’,那么执⾏完上⾯的JS后,display就被删掉了。
为了解决这个问题,可以采⽤cssText累加的⽅法:
Element.style.cssText += ‘width:100px;height:100px;top:100px;left:100px;’
海底两万里手抄报模板因此,上⾯cssText累加的⽅法在IE中是⽆效的。
最后,可以在前⾯添加⼀个分号来解决这个问题:
Element.style.cssText += ‘;width:100px;height:100px;top:100px;left:100px;’
再进⼀步,如果前⾯有样式表⽂件写着 div { text-decoration:underline; },这个会被覆盖吗?不会!因为它不是直接作⽤于 HTML 元素的 style 属性。
环保英语关于IE中tAttribute的cssText兼容问题
Firefox和IE的JS兼容性:设置元素style属性
在IE下tAttribute设置元素的对象、集合和事件属性都只当成普通属性,起不到原有的作⽤,但可以直接进⾏赋值操作,如下:
var cssText = ”font-weight:bold;color:red;”
//下⾯写法⽤于firefox类型浏览器
element.tAttribute("style",cssText);
//下⾯写法⽤于IE类型浏览器
element.style.cssText = cssText;

本文发布于:2023-06-20 23:02:59,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/fan/89/1047530.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:属性   样式   设置
相关文章
留言与评论(共有 0 条评论)
   
验证码:
推荐文章
排行榜
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图