js脚本化css

js,css · 浏览次数 : 0

小编点评

本篇文档主要介绍了如何使用JavaScript获取和设置DOM元素的样式以及元素的位置信息。通过使用原生JavaScript的方法,可以实现对元素样式的读取和修改,以及元素在页面中的定位。 1. **获取计算后的样式**: - 使用`window.getComputedStyle()`获取计算后的样式。 - 使用`element.currentStyle`在IE8及以下版本中获取计算后的样式。 - 示例代码展示了如何获取元素的宽度、高度和背景颜色。 2. **操作元素样式**: - 通过获取计算后的样式值,可以修改元素的样式。 - 示例代码演示了如何通过修改`width`属性来改变元素的大小。 3. **快捷位置和尺寸**: - DOM提供了获取元素显示尺寸的API,如`offsetWidth`、`offsetHeight`、`clientWidth`和`clientHeight`。 - 这些API兼容各种浏览器,且不受IE6、7兼容性问题影响。 4. **获取元素的有定位属性的父级**: - 使用`offsetParent`属性可以找到元素的有定位属性的父级元素。 - 示例代码说明了如何查找具有定位属性的元素。 5. **获取元素的滚动值**: - 包含了获取滚动元素的宽高、滚动距离和滚动条滚动距离的方法。 - 示例代码展示了如何获取页面滚动条的滚动距离。 6. **获取浏览器窗口的尺寸**: - 使用`window.innerWidth`和`window.innerHeight`获取浏览器窗口的尺寸。 - 示例代码说明了如何在标准模式和非标准模式下获取窗口尺寸。 7. **设置滚动条的滚动距离**: - 提供了`window.scrollTo()`、`window.scrollBy()`和`element.scrollTo()`等方法来设置滚动条的滚动距离。 总的来说,本篇文档详细介绍了使用JavaScript获取和设置DOM元素样式以及元素位置信息的方法,涵盖了从基础样式到高级布局技术的各个方面,为前端开发者提供了全面的工具集。

正文

脚本化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相似的内容:

js脚本化css

脚本化CSS 我们刚讲过如何获取和设置行内样式的值,但是我们开发不会所有样式都写在行内,同时js没法获取内嵌样式表和外部样式表中的值. 事实上DOM提供了可靠的API,得到计算后的样式。 1. 获取计算样式表 只读,不可写 获取的值是计算后的绝对值,不是相对值 window.getComputedS

blazor优雅的方式导入组件相关的js脚本

基本的组件导入方式为: 1 await JsRuntime.InvokeVoidAsync("import", $"XXXXX.js"); 优雅的组件导入方式: 1 await JsRuntime.ImportAsync(); 这种优雅一点不难,只需要写一个扩展方法,把他放在任

解决HtmlUnit执行JS报错提示ScriptException

问题描述 HtmlUnit作为一款比Selenium更轻量的HeadLess的Java版本浏览器模拟器,不需要在服务器上安装部署浏览器及其Driver程序。 但是,众所周知,HtmlUnit对JS脚本的支持并不是很友好,GitHub中大部分的issue都和JS执行错误有关,作者也一直在升级JS En

《最新出炉》系列初窥篇-Python+Playwright自动化测试-14-playwright操作iframe-番外篇

1.简介 通过前边三篇的学习,想必大家已经对iframe有了一定的认识和了解,今天这一篇主要是对iframe的一些特殊情况的介绍和讲解,主要从iframe的定位、监听事件和执行js脚本三个方面进行展开介绍。 2.iframe定位 2.1动态id属性如何定位 有时候,我们可能看到的iframe 的id

如何使用zx编写shell脚本

前言 在这篇文章中,我们将学习谷歌的zx库提供了什么,以及我们如何使用它来用Node.js编写shell脚本。然后,我们将学习如何通过构建一个命令行工具来使用zx的功能,帮助我们为新的Node.js项目引导配置。 编写Shell脚本的问题 创建一个由Bash或者zsh执行的shell脚本,是自动化重

第120篇: DOM编程(常用操作、动态脚本、样式及动态表格)

好家伙,我回来了, 本篇为《JS高级程序设计》第十四章“DOM编程”学习笔记 1.DOM编程 我们知道DOM是HTML文档的编程接口, 我们可以通过HTML代码实现DOM操作, 也同样能够通过JavaScript实现DOM操作。 2.JS操作DOM 我们来简单的举个例子: 随便开一个空白的html页

[转帖]jmeter 响应时间rt很小,但是tps也很小&jmeter,脚本处理,千万不要用js

一、背景: 在压测的时候,查看jmeter聚合报告,发现rt很小,但是tps也很小。 讲道理来说,响应时间越小,tps应该越大。 一共压测10分钟,发现jmeter请求的样本数量非常小,才8500个请求。 10分钟内,才打出了8500个请求。 tps= 总样本数量/总时间。 时间是固定的600s,总

博客园主题修改分享 - 脚本篇

如题,本期主要是通过脚本来实现博客园的各自自定义效果 说明 脚本运行需要开通博客园的JS权限,不懂的可以去看上篇文章 博客园主题修改分享 里的 增加鼠标动效; 脚本内容有一定限制,譬如禁止 window.open 之类的,也是为了防范不安全的诱导,希望各位博主们只是为了博客界面的美化或者实现一些小插

有JSDoc还需要TypeScript吗

这听起来是不是很耳熟:你想写一个小型脚本,不管是为页面、命令行工具,还是其他什么类型。你从JavaScript开始,直到你想起写代码时没有类型是多么痛苦。所以你把文件从`.js`重命名为`.ts`。然后意识到你已经打开了一个麻烦的玩意儿。 如果你在为一个网站或一个库写代码,你就需要引入编译的步骤。如

JS引擎中的线程,事件循环,上下文

线程 浏览器中有哪些进程呢? 1.浏览器进程:浏览器的主进程,负责浏览器的界面界面显示,与用户交互,网址栏输入、前进、后退,以及页面的创建和销毁。 2.渲染进程(浏览器内核):默认一个tab页面一个渲染进程,主要的作用为页面渲染,脚本执行,事件处理等。 3.GPU进程:用于3D绘制等,将开启了3D绘