博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
cssText基本使用及注意事项
阅读量:6258 次
发布时间:2019-06-22

本文共 1370 字,大约阅读时间需要 4 分钟。

一、cssText之起步

那些年,我们是这样设置样式的:

xxx.style.width = "233px";xxx.style.position = "fixed";xxx.style.left = "233px";

现如今,我们可以这样搞:

xxx.style.cssText = "width:233px; height:233px; position:fixed";

W3C是这样描述cssText

cssText,DOMString类型cssText特性必须返回序列化的CSS规则。当设置cssText特性时运行这些步骤: 1. 解析其值。 2. 如果解析失败则终止运行。 3. 如果新对象的type并不匹配当前对象的type则抛出"InvalidModificationError"异常。 4. 替换当前对象为新对象。

请注意第四条:也就是说会覆盖到目标元素之前本身所具有的全部样式(继承的不算)。

举个栗子:

这里有一个<div>,长下面这个模样:

.xxx {
height:233px;width:233px;background:#F60;}

然后我要改变它的高度,我可以这么写:

xxx.style.height= "466px";

但是不可以这么写:

xxx.style.cssText="height:466px;";

 

二、cssText之提速

基于上面的原因,我们在使用cssText修改某个元素样式的时候,需要首先得到它当前的样式:

var xxx = document.getElementById("warp");var xxx_style = xxx.style.cssText;

然后在加上现在的样式:

xxx_style += "position:fixed;"xxx.style.cssText = xxx_style;

但是,如果需要IE6/7/8完美支持,那就需要注意了

当我们使用 var xxx_style = xxx.style.cssText;得到样式的时候,最后是没有分号的

也就是说,如果某个元素的样式是:

height: 100px; width: 100px;overflow: hidden;

在IE6/7/8下我们会得到:

HEIGHT: 100PX; WIDTH: 100PX; OVERFLOW: HIDDEN

最后的分号被丢掉了。

结果就是当我们再使用

xxx_style += "background:#F60;"xxx.style.cssText = xxx_style;

来处理样式时,会出现:

height: 100px; width: 100px; overflow: hiddenbackground:#F60;

当然你可以选择使用:xxx_style = "background:#F60;" + xxx_style的方式,最后没有分号也不会影响,但是世事难料,安全起见,还是额外判断一下,补上这个分号比较可靠。

除此以外,IE6/7/8下返回的属性和值全是大写,为了避免日后出现意外,还是.toLowerCase( )比较好。

 

文章转自:

 

转载于:https://www.cnblogs.com/lvmylife/p/5896652.html

你可能感兴趣的文章
利用PowerShell复制SQLServer账户的所有权限
查看>>
SQLServer 维护脚本分享(10)索引
查看>>
js里父页面与子页面的相互调用
查看>>
AES加解密【示例】
查看>>
jdbc向各种数据库发送sql语句
查看>>
比特币进一步学习-针对作弊问题的处理
查看>>
Android实现手机摄像头的自动对焦
查看>>
ASCII流程图
查看>>
Linux知识积累(5) 关机shutdown和重启reboot
查看>>
HTML5为输入框添加语音输入功能
查看>>
[LeetCode] Find Permutation 找全排列
查看>>
os.environ() 说明
查看>>
Python学习札记(二十) 函数式编程1 介绍 高阶函数介绍
查看>>
tomcat安装不成功.提示:failed to install tomcat6 service ,check your setting and permissions
查看>>
[转]当当网高可用架构之道--转
查看>>
ROS学习网址【原创】
查看>>
mysql数据库对时间进行默认的设置
查看>>
喵哈哈村的魔法考试 Round #3 (Div.2) 题解
查看>>
音频 API 一览
查看>>
hive的select重命名字段显示成中文
查看>>