js脚本化css
脚本化CSS
我们刚讲过如何获取和设置行内样式的值,但是我们开发不会所有样式都写在行内,同时js没法获取内嵌样式表和外部样式表中的值.
事实上DOM提供了可靠的API,得到计算后的样式。
1. 获取计算样式表
只读,不可写
获取的值是计算后的绝对值,不是相对值
window.getComputedStyle(ele,null).attr IE8以上
ele.currentStyle IE8及其以下
例子:
window.getComputedStyle(ele).attr
// 当然window是可以省略的
getComputedStyle(ele).attr
好用的东西,一定不兼容。所以IE6、7、8不兼容
附加在元素身上的currentStyle属性,它表现和style点语法一样,使用驼峰式访问
例子
oDiv.currentStyle.width
之前讲过,点操作符必须符合标识符的规范,所以使用点操作符获取有连字符的属性要写成驼峰式
getComputedStyle(oDiv).backgroundColor;
oDiv.currentStyle.backgroundColor;
中括号操作符,因为中括号内写字符串,所以不用遵循标识符规范,就可以保留连字符的写法
getComputedStyle(oDiv)['background-color'];
oDiv.currentStyle['background-color'];
颜色值在高级浏览器中是rgb()格式,低级浏览器中就是原样输出。
示例:
封装getStyle(dom,attr)兼容性
实际上,老司机都不这么做。我们不关心你的版本是什么,我只关心你的能力。
function getStyle(ele,attr){
if(window.getComputedStyle){
return getComputedStyle(ele)[attr];
}else{
return ele.currentStyle[attr];
}
}
function getStyle(dom,attr){
if(dom.currentStyle){ // IE8 及其一下
return dom.currentStyle[attr]
}else{
return getComputedStyle(dom,null)[attr]
}
}
现在我们要在一个轮子,就是封装一个函数,这个函数接收两个参数,第一个是对象,第二个是属性名。
getStyle(obj,”padding-left”);
getStyle(obj,”paddingLeft”);
这个函数返回的是这个属性值的计算后的样式。更牛逼的是,我们无论用户输入的是驼峰还是非驼峰,都让这个函数鲁棒。
2. 操作元素样式
我们知道前面学过了如果设置样式通过行内style来设置元素样式,
那么我们就可以通过获取计算样式值,然后修改
var oBox = document.getElementById('box');
var wid = parseInt(getStyle(oBox,'width'));
oBox.onclick = function(){
wid += 20;
console.log(wid);
oBox.style.width = wid + 'px';
}
3. 快捷位置和尺寸
DOM已经提供给我们计算后的样式,但是还觉得不方便,所以DOM又提供给我们一些API:
获取元素的显示尺寸(数字类型的值)
ele.offsetWidth width+左右padding+左右border
ele.offsetHeight height+上下padding+上下border
ele.offsetLeft 水平距离 (常用)
ele.offsetTop 竖直距离 (常用)
ele.clientWidth width+左右padding (常用)
ele.clientHeight height+上下padding (常用)
dom.clientLeft 上边框的width (可不记)
dom.clientTop 左边框的width (可不记)
3.1. offsetWidth和offsetHeight
全线兼容,是自己的属性,和别的盒子无关。
一个盒子的offsetWidth值就是自己的 width+左右padding+左右border的宽度(说白就是盒子的大小)
总结一下,全线兼容。
3.2. offsetLeft属性和offsetTop
这两个属性的兼容性非常差,不要着急,我们慢慢来看。
IE9、IE9+、Chrome等高级浏览器:
一个元素的offsetLeft值,就是这个元素左边框外,到自己的offsetParent对象的左边框内的距离
每一个元素,天生都有一个属性,叫做offsetParent
就是自己祖先元素中,离自己最近的已经定位的元素,如果自己的祖先元素中,没有任何盒子进行了定位,那么offsetParent对象就是body。
op.offsetParent; // 查找离自己最近的定位父级
无论这个盒子自己是否定位,自己的offsetParent就是按照上述方法寻找。
IE6、IE7:
IE6、7的offsetParent对象是谁,和高级浏览器有非常大的不同。
情形1:自己如果没有定位属性,那么自己的offsetParent对象就是自己的祖先元素中离自己最近的有width或者有height的元素:
<div class="box1">
<div class="box2"> → 你好,我有宽度 , offsetParent
<div class="box3"> → 你好,我没有宽高
<p></p> → 你好,我没有定位
</div>
</div>
</div>
情形2:自己如果有定位属性
那么自己的offsetParent就是自己祖先元素中离自己最近的有定位的元素。
<div class="box1">
<div class="box2">
<div class="box3"> → 你好,我没有宽高,有定位 , offsetParent
<p></p> → 你好,我没有定位
</div>
</div>
</div>
数值就是自己的左外边框到offsetParent对象的左内边框的值。
IE8:
IE8的offsetParent是谁呢?和高级浏览器一致:
无论自己是否定位,自己的offsetParent就是自己祖先元素中,离自己最近的已经定位的元素。
这一点,没有任何兼容问题!
兼容性解决办法,不是能力检测,也不是版本检测,而是善用这个属性,要确保属性的使用条件:
这样的话,所有浏览器的值都是一样的,offsetLeft、offsetTop值是number类型的,可以直接参与运算,不需要parseInt()
3.3. clientWidth和clientHeight
clientWidth就是自己的width+padding的值。 也就是说,比offsetWidth少了border。
如果盒子没有高度,用文字撑的,IE6 clientHeight是0,其他浏览器都是数值。
以上6个属性要铭记于心,就offsetLeft、offsetTop比较闹腾,但是合理使用,也没兼容问题了
3.4. clientLeft和clientTop
这两个属性没有太大的意义就是上边框和左边看的宽度而已
4. 获取元素的有定位属性的父级
ele.offsetParent
如果没有定位父节点,则返回body
封装getElementPosition函数,获取元素相对于文档的坐标
function getElePos(dom){ // 获取元素相对于文档的坐标
var x = dom.offsetLeft;
var y = dom.offsetTop;
var parent = dom.offsetParent;
while(parent !== null){
x += parent.offsetLeft;
y += parent.offsetTop;
parent = parent.offsetParent;
}
return {
x: x,
y: y
}
}
5. 获取元素的滚动值
5.1 获取滚动元素的宽高
当元素实际内容超过设置的内容时
dom.scrollWidth ==> 元素实际内容的width
dom.scrollHeight ==> 元素实际内容的height
5.2 获取元素的滚动距离(数字类型的值)
dom.scrollLeft 滚动的水平距离
dom.scrollTop 滚动的竖直距离
5.3 滚动距离的兼容写法
- 获取滚动条的滚动距离 IE8以上
window.pageXOffset 页面滚动的水平距离
window.pageYOffset 页面滚动的竖直距离
- 获取滚动条的滚动距离 IE8及其以下
document.documentElement.scrollLeft IE7,8
document.documentElement.scrollTop IE7,8
document.body.scrollLeft
document.body.scrollTop
在IE8以上兼容性比较混乱,在使用时两个值相加,因为这两对值不能同时存在
封装getScrollOffset兼容性函数
function getScrollOffset(){
if(window.pageYOffset){
return {
x: window.pageXOffset,
y: window.pageYOffset
}
}else{
return {
x: document.documentElement.scrollLeft + document.body.scrollLeft,
y: document.documentElement.scrollTop + document.body.scrollTop;
}
}
}
6. 获取浏览器窗口的尺寸
IE8以上
window.innerWidth 窗口的宽度(包含滚动条)
window.innerHeight 窗口的高度(包含滚动条)
IE8及其以下
document.documentElement.clientWidth 标准模式下
document.documentElement.clientHeight
(在Chrome,Firefox,IE7,IE8不包含滚动条,在IE8以上包含滚动条)
document.body.clientWidth 怪异模式下
document.body.clientWidth
检测浏览器是不是在怪异模式下
dowument.compatMode === 'BackCompat'
封装getViewportOffset兼容性函数
function getViewportOffset(){
if(window.innerWidth){
return {
x: window.innerWidth,
y: window.innerHeight
}
}else{
if( document.compatMode === 'BackCompat'){
return {
x: document.body.clientWidth,
y: document.body.clientHeight
}
}else{
return {
x: document.documentElement.clientWidth,
y: document.documentElement.clientHeight
}
}
}
}
7. 设置滚动条的滚动距离
浏览器页面滚动
window.scrollTo(x,y) 让滚动条滚动到指定位置
window.scrollBy(x,y) 让滚动条滚动指定距离
页面元素滚动
ele.scrollTo(x,y)
ele.scrollBy(x,y)
js脚本化css的更多相关文章
- 深入理解脚本化CSS系列第六篇——脚本化伪元素的6种方法
× 目录 [1]动态样式 [2]CSS类[3]setAttribute()[4]CSSRule对象添加[5]空样式覆盖[6]CSSRule对象删除 前面的话 我们可以通过计算样式来读取伪元素的样式信息 ...
- 深入理解脚本化CSS系列第四篇——脚本化样式表
× 目录 [1]CSSStyleSheet [2]CSSRule 前面的话 关于脚本化CSS,查询样式时,查询的是计算样式:设置单个样式时,设置的是行间样式:设置多个样式时,设置的是CSS类名.脚本化 ...
- 深入理解脚本化CSS系列第三篇——脚本化CSS类
前面的话 在实际工作中,我们使用javascript操作CSS样式时,如果要改变大量样式,会使用脚本化CSS类的技术,本文将详细介绍脚本化CSS类 style 我们在改变元素的少部分样式时,一般会直接 ...
- 深入理解脚本化CSS系列第一篇——脚本化行内样式
× 目录 [1]用法 [2]属性 [3]方法 前面的话 脚本化CSS,通俗点说,就是使用javascript来操作CSS.引入CSS有3种方式:外部样式,内部样式和行间样式.本文将主要介绍脚本化行间样 ...
- JavaScript权威指南--脚本化CSS
知识要点 客户端javascript程序员对CSS感兴趣的是因为样式可以通过脚本编程.脚本化css启用了一系列有趣的视觉效果.例如:可以创建动画让文档从右侧“滑入”.创造这些效果的javascript ...
- 浅谈脚本化css(二)
查询计算样式 window上面有一个方法叫做getComputedStyle可以来获取元素的计算样式,也就是css样式. window.getComputedStyle(ele. null); J ...
- 关于脚本化css
---恢复内容开始--- 想把自己认为的最重要的,最有用的几块写上,以后会边学边总结完善. 1.首先我们通过JavaScript可以获取到我们想要获取的元素的样式.而这个样式并非单独的哪一个部分的规则 ...
- 脚本化CSS(通过JS来间接操作CSS)
(一)通过.style.形式,获取的是行间样式,可读可写 1.行间样式语法 1 <div style="width:100px;border:5px solid red;height: ...
- 浅谈脚本化css(一)
读写css属性 每一个dom元素都有一个属性style,dom.style里面存放的这个元素的行间样式,我们可以通过这个属性来读写元素的行间样式. 注意: 1.我们碰到float这样的关键字属性的时候 ...
- 深入理解脚本化CSS系列第二篇——查询计算样式
× 目录 [1]getComputedStyle [2]注意事项 [3]currentStyle[4]IE 前面的话 元素的渲染结果是多个CSS样式博弈后的最终结果,这也是CSS中的C(cascade ...
随机推荐
- OLAP开源引擎对比之历史概述
前言 OLAP概念诞生于1993年,工具则出现在更早以前,有史可查的第一款OLAP工具是1975年问世的Express,后来走进千家万户的Excel也可归为此类,所以虽然很多数据人可能没听过OLAP, ...
- sendmail发送慢的问题
1.使用python的脚本,发送邮件.代码如下: 点击查看代码 [root@ZabbixServerMasterNode ~]# cd /etc/zabbix/alertscripts/ [root@ ...
- Linux — 物理内存管理
物理内存的组织方式 物理内存是由连续的一页一页的块组成,每个物理页都有页号 每个页由struct page表示,放进数组里--平坦内存模型 SMP和NUMA SMP中,总线会称为瓶颈,因为数据都要经过 ...
- 【漏洞分析】HPAY 攻击事件分析
背景 造成本次攻击的原因是关键函数的鉴权不当,使得任意用户可以设置关键的变量值,从而导致攻击的发生. 被攻击合约:https://www.bscscan.com/address/0xe9bc03ef0 ...
- 密码学—Vigenere破解Python程序
文章目录 概要 预备知识点学习 整体流程 技术名词解释 技术细节 小结 代码 概要 破解Vigenere需要Kasiski测试法与重合指数法的理论基础 具体知识点细节看下面这两篇文章 预备知识点学习 ...
- 2024-05-18:用go语言,给定一个从 0 开始的字符串 s,以及两个子字符串 a 和 b,还有一个整数 k。 定义一个“美丽下标”,当满足以下条件时: 1.找到字符串 a 在字符串 s 中的位
2024-05-18:用go语言,给定一个从 0 开始的字符串 s,以及两个子字符串 a 和 b,还有一个整数 k. 定义一个"美丽下标",当满足以下条件时: 1.找到字符串 a ...
- 继承与ER图
会员是用户吗? 实体与集合 er图叫实体联系图.什么是实体?是现实中存在的事物个体,用户背后是实际存在的单个人. 对象->实体 类->实体的集合 er图描述的是实体间的联系 会员是真实存在 ...
- 自动化部署elasticsearch三节点集群
什么是Elasticsearch? Elasticsearch 是一个开源的分布式搜索和分析引擎,构建在 Apache Lucene 的基础上.它提供了一个分布式多租户的全文搜索引擎,具有实时分析功能 ...
- LLM实战:当网页爬虫集成gpt3.5
1. 背景 最近本qiang~关注了一个开源项目Scrapegraph-ai,是关于网页爬虫结合LLM的项目,所以想一探究竟,毕竟当下及未来,LLM终将替代以往的方方面面. 这篇文章主要介绍下该项目, ...
- 一文带你了解.NET能做什么?
前言 在DotNetGuide技术社区微信交流群经常看到有小伙伴问:.NET除了能写桌面应用和Web应用还能做什么?今天大姚将通过本篇文章来简单讲讲.NET能做哪些开发,对.NET感兴趣的小伙伴也可以 ...