js正确获取元素样式详解


Posted in Javascript onAugust 07, 2009

在说js获取元素样式之前,简单地谈一下样式

样式分三种
外部样式 External Style Sheet
以CSS为扩展名的文件(又称为"超文本样式表"文件),它的作用范围可以是多张网页,或整个网站,甚至不同的网站。与网页链接后,才能应用。
嵌入式样式 internal Style Sheet
包含在网页内部的样式设置,它的作用范围仅限于嵌入的网页。
内联式样式 inline Style
在HTML文档中,内联式样式表的格式化信息直接插入所应用的网页元素的HTML标签中,作为其HTML标签的属性参数。严格地说,内联样式表称不上表,仅仅是一条HTML标记。
当出现相同的样式时,优先级是内联大于嵌入式样式, 嵌入式样式大于外部样式。
---------------------------------------------------------------
当js获取这三种样式时,style只能获取内联样式,获取不到外部样式和嵌入式样式,因此要用currentStyle属性,而currentStyle在FF下不支持
下面介绍二种 兼容FF和IE和正确获取样式的方法

var $=function(id){return document.getElementById(id) }; 
方法一 
/* 
* @string id 
* @string styleName 样式名 
*/ 
function getEyeJsStyle(id,styleName){ 
if($(id).currentStyle){//ie 
return $(id).currentStyle[styleName]; 
}else{ //ff 
var $arr=$(id).ownerDocument.defaultView.getComputedStyle($(id), null); 
return $arr[styleName]; 
} 
}

方法二:
HTMLElement.prototype.__defineGetter__("currentStyle", function () { 
return this.ownerDocument.defaultView.getComputedStyle(this, null); 
});

讲述一下getComputedStyle函数的用法
这个函数有两个参数:
第一个参数为需要获取样式的元素对象;
第二个参数为伪元素,如:hover, :first-letter, :before等等,
如果不需要伪元素则该参数为null。
getComputedStyle()函数可以从 document.defaultView 对象中访问到,即可以这样调用该函数
--------------------------------------------------------------------------------------------

顺便说一下runtimeStyle属性,首页该属性只在IE中支持,在FF不支持
runtimeStyle 运行时的样式!如果与style的属性重叠,将覆盖style的属性!
意思就是当指定了runtimeStyle,那么当前显示的样式以runtimeStyle为准,如果取消了runtimeStyle,那么当前显示样式就恢复到currentStyle的样式。
案例:
设置document.getElementById("eyejs").runtimeStyle.width="400px"; 那该元素的宽度就是400px,,将覆盖style的属性
案例分析打包下载

Javascript 相关文章推荐
dojo 之基础篇(二)之从服务器读取数据
Mar 24 Javascript
javascript下查找父节点的简单方法
Aug 13 Javascript
Javascript Math对象
Aug 13 Javascript
jQuery 行级解析读取XML文件(附源码)
Oct 12 Javascript
基于jquery的防止大图片撑破页面的实现代码(立即缩放)
Oct 24 Javascript
解决node-webkit 不支持html5播放mp4视频的方法
Mar 11 Javascript
jQuery可见性过滤选择器用法示例
Sep 09 Javascript
详解如何使用webpack在vue项目中写jsx语法
Nov 08 Javascript
JavaScript+H5实现微信摇一摇功能
May 23 Javascript
JS通过ajax + 多列布局 + 自动加载实现瀑布流效果
May 30 Javascript
VUE : vue-cli中去掉路由中的井号#操作
Sep 04 Javascript
Vue3实现简易音乐播放器组件
Aug 14 Vue.js
JavaScript 乱码问题
Aug 06 #Javascript
jquery ui dialog里调用datepicker的问题
Aug 06 #Javascript
jquery select(列表)的操作(取值/赋值)
Aug 06 #Javascript
asp(javascript)全角半角转换代码 dbc2sbc
Aug 06 #Javascript
javascript Array.remove() 数组删除
Aug 06 #Javascript
实现连缀调用的map方法(prototype)
Aug 05 #Javascript
Extjs ajax同步请求时post方式参数发送方式
Aug 05 #Javascript
You might like
PHP 日,周,月点击排行统计
2012/01/11 PHP
PHP中cookie和session的区别实例分析
2014/08/28 PHP
PHP的Yii框架中行为的定义与绑定方法讲解
2016/03/18 PHP
Avengerls vs Newbee BO3 第二场2.18
2021/03/10 DOTA
JavaScript初学者应注意的七个细节小结
2012/01/30 Javascript
JavaScript高级程序设计 读书笔记之十一 内置对象Global
2012/03/07 Javascript
javascript学习笔记(四) Number 数字类型
2012/06/19 Javascript
用JavaScript修改CSS属性的代码
2013/05/06 Javascript
jQuery中:has选择器用法实例
2014/12/30 Javascript
浅析js的模块化编写 require.js
2016/12/07 Javascript
微信小程序之拖拽排序(代码分享)
2017/01/21 Javascript
Bootstrap 树控件使用经验分享(图文解说)
2017/11/06 Javascript
10个在JavaScript开发中常遇到的BUG
2017/12/18 Javascript
讲解vue-router之什么是编程式路由
2018/05/28 Javascript
JS实现移动端触屏拖拽功能
2018/07/31 Javascript
vue递归组件实战之简单树形控件实例代码
2019/08/27 Javascript
微信小程序表单验证WxValidate的使用
2019/11/27 Javascript
vue使用nprogress实现进度条
2019/12/09 Javascript
怎么理解wx.navigateTo的events参数使用详情
2020/05/18 Javascript
在vue中实现echarts随窗体变化
2020/07/27 Javascript
Python 错误和异常小结
2013/10/09 Python
详解Python2.x中对Unicode编码的使用
2015/04/03 Python
Python实现HTTP协议下的文件下载方法总结
2016/04/20 Python
Python操作rabbitMQ的示例代码
2019/03/19 Python
Python 3.6 中使用pdfminer解析pdf文件的实现
2019/09/25 Python
Pytorch之卷积层的使用详解
2019/12/31 Python
使用已经得到的keras模型识别自己手写的数字方式
2020/06/29 Python
德国化妆品和天然化妆品网上商店:kosmetikfuchs.de
2017/06/09 全球购物
英国领先的汽车轮胎和快速健康中心:Kwik Fit
2017/10/29 全球购物
澳大利亚女士时装在线:Rockmans
2018/09/26 全球购物
Joseph官网:英国小众奢侈品牌
2019/05/17 全球购物
软件工程师岗位职责
2013/11/16 职场文书
党的群众路线教育实践活动心得体会900字
2014/03/07 职场文书
交通事故赔偿协议书范本
2014/04/15 职场文书
如何在centos上使用yum安装rabbitmq-server
2021/03/31 Servers
springboot入门 之profile设置方式
2022/04/04 Java/Android