动态修改样式和层叠样式表

转自:http://www.cnblogs.com/micromouse/archive/2010/04/26/1721618.html

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;
}

时间: 2024-11-09 23:55:36

动态修改样式和层叠样式表的相关文章

如何在.cs中统一动态修改xaml中style资源定义的样式

关于设置控件属性样式的方法已经在之前的博客中有提及过,博客地址:设置控件样式的方法 当然在实际项目编写过程中,不光单纯的需要设置元素样式,有时候需要动态的修改元素的样式,这个时候就有些不 同了.需要针对不同的情形来选择不同的方法修改样式. 情形一:单纯的修改一个控件元素的样式,那么只要在.cs中仅仅针对这个控件的样式属性的修改即可. 情形二:如果是要针对同一类的所有控件的样式进行相同的属性修改,比如针对页面中所有的Label控件进行修改, 那么对应之前你在给这些Label控件设置样式的不同做法,

js 动态修改属性值 动态修改图片,字等

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"   http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html> <head> <meta http-equiv = "content-type" content="text/html;charset=utf-8"/> &

JS写动态分页样式效果

效果图如下: html: <body> <div> <table id="btnbox"> <tbody> <tr><td> <a href="#" class="btn">上一页</a> <a href="#" index="1">1</a> <a href="#&quo

vue2.0 通过v-html指令编辑的富文本无法修改样式的原因

在最近的项目中遇到的问题:v-html编辑的富文本,无法在样式表中修改样式: <template> <div class="descBox" v-html='desc'></div> </template> <script> export default{ data(){ return { desc: "<p>I believe I can fly</p>" } } } </s

动态修改类注解(赋值)

1. 动态修改注解元凶: Java代码 /**  * 对象池工具类  *   * 目前提供ORM动态映射解决方案  *   * @author andy.zheng  * @since 2012.09.25 15:55 PM  * @vesion 1.0  *   */ public class ClassPoolUtils {                  /**      * 运行时动态ORM表映射      *       *       * @param entityClassNam

js 动态修改css文件

_.find(document.styleSheets[4].cssRules,function(cssRule){ if(cssRule.selectorText && cssRule.selectorText.indexOf(".navbar-fixed-top2")>-1){ cssRule.style.position=""; cssRule.style.top = "0px"; } if(cssRule.selec

js访问外部的css 来修改样式

js访问外部的css 来修改样式,布布扣,bubuko.com

javascript中通过className灵活查找元素 例如我们要把根据class来进行修改样式

原文:javascript中通过className灵活查找元素 例如我们要把根据class来进行修改样式 一.背景:一个表单中,要修改一些li中有class=box的样式,将它的background设置为red红色.一般的做法是我们可以先找到父级元素 ,然后由父级元素找到所有相关tagName,最后,来一个if判断,如果class属性为box,则修改之 var oUl = document.getElementById("ul1");                          

Quartz总结(四):动态修改定时器二

前文:http://www.cnblogs.com/LiuChunfu/p/5598806.html 提到了一种动态修改定时器的方法, 其本质就是在job方法中注入Schedular的对象,从Schedular中获取Trigger(触发器),然后修改触发器的条件,重新启动. 前文中的方法,其实已经涉及到了循环调用. Job类 => Job => Trigger => Schedular =>Job类. 这样是很容易发生问题的,也确实在实际项目中发生了问题,特别是当Schedular