源码网,源码论坛,源码之家,商业源码,游戏源码下载,discuz插件,棋牌源码下载,精品源码论坛

 找回密码
 立即注册
查看: 189|回复: 22

[JavaScript] javascript 动态修改样式和层叠样式表代码

[复制链接]

7万

主题

861

回帖

32万

积分

论坛元老

Rank: 8Rank: 8

积分
329525
发表于 2010-4-27 16:32:59 | 显示全部楼层 |阅读模式
javascript 动态修改样式和层叠样式表代码,需要的朋友可以参考下。 W3C DOM2样式规则
==========================================================
CSSStyleSheet对象
  CSSStyleSheet对象表示的是所有CSS样式表,包括外部样式表和使用<style type="text/css"></style>标签指定的嵌入式样式表。
CSSStyleSheet同样构建于其他的DOM2 CSS对象基础之 上,而CSSStyleRule对象表示的则样式表中的每条规则。
  通过document.stylesheets属性可以取得文档中CSSStyleSheet对象的列表,其中每个对象有下列属性
  type        始终为text/css
  disabled      相应样式表是应于还是禁用于当前文档
  href        样式表相对于当前文档的URL
  title        分组样式标签
  media       样式应用的目标设备类型(screen、print)
  ownerRule     只读CSSRule对象,若样式用@import导入,表示其父规则
  cssRules      只读cssRuleList列表对象,包含样式表中所有CSSRule对象
  ==========================================================
  insertRule(rule,index)    添加新的样式声明
  deleteRule(index)      从样式表中移除规则
CSSStyleRule对象
  每个CSSStyleSheet对象内部包含着一组CSSStyleRule对象。这些对象分别对应着类似下面这样一条规则:
  boyd{
    font:lucida,verdana,sans-serif;
    background:#c7600f;
    color:#1a3800;
  }
CSSStyleRule对象具有下列属性:
  type        继承自CSSRule对象的一个属性,以0~6中的一个数字表示规则类型
  cssText       以字符串形式表示的当前状态下的全部规则
  parentStyleSheet   引用父CSSStyleRule对象
  parentRule      如果规则位于另一规则中,该属性引用另一个CSSRule对象
  selectorText     包含规则的选择符
  style        与HTMLElement.style相似,是CSSStyleDeclaration对象的一个实例
CSSStyleDeclaration对象
  表示一个元素的style属性,与CSSStyleRule对象类似,CSSStyleDeclaration具有下面属性:
  cssText    以字符串形式表示的全部规则
  parentRule   将引用CSSStyleRule对象
  ==========================================================
  getPropertyValue(propertyName)      CSS样式属性值
  removeProperty(propertyName)       从声明中移除属性
  setProperty(propertyName,value,priority)   设置CSS属性值
把样式置于DOM脚本之外
=========================================================
style属性
  style属性本身是一个表示特定元素的所有不同CSS样式的CSSStyleDeclaration对象,通过style属性只能访问到在元素的style属性中以嵌入方式声明的CSS属性。换句话说,通过style属性无法访问到由多重样式表层叠而来或者从父元素继承的CSS属性。
复制代码 代码如下:
element.style.backgroundColor = 'red';  //background-color被转换为大小写形式,必须的
//设置id为"example"的元素的样式
setStyleById('example',{
  'background-color'   :   'red',
  'border'       :  '1px solid black',
  'padding'       :  '1px',
  'margin'       :  '1px'
});
function setStyle(elementid,styles){ 
  var element = document.getElementById(elementid);
  //循环遍历styles对象并应用每个属性
  for(property in styles){
    //非styles直接定义的属性
    if(!styles.hasOwnProperty(property)) continue;
    
    if(element.style.setProperty){
      element.style.setProperty(uncamlize(property, '-'), styles[property], null);
    } else {
      element.style[camelize(property)] = styles[property];
    }
  }
  
  return true;
}
//将word-word转换为wordWord
function camelize(s) {
return s.replace(/-(\w)/g, function(math,p1){
return p1.toUpperCase();
});
}
//将wordWord转换为word-word
function uncamelize(s, sep) {
sep = sep || '-';
return s.replace(/([a-z])([A-Z])/g, function (match, p1, p2){
return p1 + sep + p2.toLowerCase();
});
}
//基于className切换样式
element.className += 'newclass';

访问计算样式
  在修改一个元素的表现之前,你可能希望首先确定它当前的样式属性,由于元素的style属性只适用于以嵌入式方式定义的样式,因此无法通过style取得计算样式,DOM2规范在document.defaultView中包含一个名叫getComputedStyle()的方法,该方法返回一个只读的CSSStyleDeclaration对象,包含特定元素的所有计算样式,如下:
复制代码 代码如下:
  var styles = document.defaultView.getComputedStyle(element);
  var color = styles.getProperty('background-color');

但是Microsoft有自己的属性element.currentStyle版本
复制代码 代码如下:
//取得一元素的计算样式
function getStyle(element,property) {
  var value = element.style[camelize(property)];
  if(!value) {
    if(document.defaultView && document.defaultView.getComputedStyle) {
      value = document.defaultView.getComputedStyle(element).getPropertyValue(property);
    } else if(element.currentStyle) {
      value = element.currentStyle[camelize(property)];
     }
  }
  return value;
}
回复

使用道具 举报

2

主题

2万

回帖

67

积分

注册会员

Rank: 2

积分
67
发表于 2022-8-13 00:07:06 | 显示全部楼层
那三门,你们谁寂寞才快乐撒
回复 支持 反对

使用道具 举报

2

主题

2万

回帖

499

积分

中级会员

Rank: 3Rank: 3

积分
499
发表于 2022-8-29 13:57:38 | 显示全部楼层
儿童服务绯闻绯闻绯闻
回复 支持 反对

使用道具 举报

0

主题

2万

回帖

0

积分

中级会员

Rank: 3Rank: 3

积分
0
发表于 2022-10-25 00:08:33 | 显示全部楼层
先把创新班才能下班才能下班
回复 支持 反对

使用道具 举报

0

主题

1万

回帖

68

积分

注册会员

Rank: 2

积分
68
发表于 2022-12-19 15:28:09 | 显示全部楼层
额头额定法国队是范德萨
回复 支持 反对

使用道具 举报

0

主题

2万

回帖

115

积分

注册会员

Rank: 2

积分
115
发表于 2023-8-4 13:18:48 | 显示全部楼层
hi哦和烦恼农家女
回复 支持 反对

使用道具 举报

0

主题

1万

回帖

68

积分

注册会员

Rank: 2

积分
68
发表于 2023-8-13 04:47:15 | 显示全部楼层
额风风风微风微风违法
回复 支持 反对

使用道具 举报

0

主题

2万

回帖

0

积分

中级会员

Rank: 3Rank: 3

积分
0
发表于 2023-8-22 23:29:32 | 显示全部楼层
554411515451555
回复 支持 反对

使用道具 举报

0

主题

1万

回帖

0

积分

中级会员

Rank: 3Rank: 3

积分
0
发表于 2023-10-9 11:48:17 | 显示全部楼层
快更新啊,我擦
回复 支持 反对

使用道具 举报

2

主题

2万

回帖

473

积分

中级会员

Rank: 3Rank: 3

积分
473
发表于 2023-11-14 08:49:33 | 显示全部楼层
iiguuubhuiuihu
回复 支持 反对

使用道具 举报

高级模式
B Color Image Link Quote Code Smilies

本版积分规则

手机版|小黑屋|网站地图|源码论坛 ( 海外版 )

GMT+8, 2024-11-23 01:20 , Processed in 0.117387 second(s), 26 queries .

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表