使用JS操作内联样式
操作内联样式
通过JS修改元素的样式:
语法: 元素 .style .样式名 = 样式值
例:
box1.style.width = "300px";
注意:如果CSS的样式名中含有-,
这种名称在JS中是不合法的比如background-color
需要将这种样式名修改为驼峰命名法,backgroundColor
我们通过style属性设置的样式都是内联样式,
而内联样式有较高的优先级,所以通过JS修改的样式往往会立即显示
但是如果在样式中写了! important,则此时样式会有最高的优先级,
即使通过JS也不能覆盖该样式,此时将会导致JS修改样式失效
所以尽量不要为样式添加! important
读取元素的样式
读取box1的样式
var btn02 = document.getElementById( "btn02");
btn02.onclick = function(){
alert(box1.style.backgroundColor);
};
语法: 元素 .style .样式名
通过style属性设置和读取的都是内联样式
无法读取样式表里面的属性
//点击按钮以后读取box1的样式
var box1 = document.getElementById("box1");
var btn01 = document.getElementById( "btn01");
btn01.onclick = function( ){
//读取box1的宽度
//alert(box1. style.width);
获取元素的当前显示的样式
语法: 元素 .currentStyle .样式名
alert(box1.currentStyle.width);
它可以用来读取当前元素正在显示的样式
如果当前元素没有设置该样式,则获取它的默认值
currentStyle只有IE浏览器支持,其他的浏览器都不支持
在其他浏览器中可以使用getComputedstyle( )这个方法来获取元素当前的样式
这个方法是window的方法,可以直接使用
需要两个参数
第一个:要获取样式的元素
第二个:可以传递一个伪元素,一般都传null
alert(getComputedStyle(box1,null).width);
该方法会返回一个对象,对象中封装了当前元素对应的样式
可以通过对象.样式名来读取样式
如果获取的样式没有设置,则会获取到真实的值,而不是默认值
比如:没有设置width,它不会获取到auto,而是一个长度
但是该方法不支持工E8及以下的浏览器
通过currentStyle和getComputedStyle( )读取到的样式都是只读的,
不能修改,如果要修改必须通过style属性
构建函数读取样式
定义一个函数,用来获取指定元素的当前的样式
参数:
obj 要获取样式的元素
name 要获取的样式名
function getStyle(obj,name){
//正常浏览器的方式
//return getComputedStyle(obj ,null) [name];
//IE8的方式
//return obj.currentStyle[name] ;
}
为了更好的兼容了浏览器获取样式,可以使用以下方法
function getStyle(obj ,name){
if(window. getComputedstyle){
//正常浏览器的方式,具有getComputedStyle()方法
return getComputedStyle(obj,null)[name];
}else{
//IE8的方式, 没有getComputedstyle( )方法
return obj.currentStyle[name];
}
//或者
return window. getComputedstyle?getComputedstyle(obj,null)[name]:obj.currentStyle[name];
}
clientWidth
clientHeight
这两个属性可以获取元素的可见宽度和高度
这些属性都是不带px的,返回都是一个数字,可以直接进行计算
会获取元素宽度和高度,包括内容区和内边距
这些属性都是只读的,不能修改
offsetWidth
offsetHeight
获取元素的整个的宽度和高度,包括内容区、内边距和边框
offsetParent
可以用来获取当前元素的定位父元素
会获取到离当前元素最近的开启了定位的祖先元素
如果所有的祖先元素都没有开启定位,则返回body
offsetLeft
当前元素相对于其定位父元素的水平偏移量
offsetTop
当前元素相对于其定位父元素的垂直偏移量
scrollWidth
scrollHeight
可以获取元素整个滚动区域的宽度和高度
当满足scrollHeight - scrollTop = clientHeight
说明垂直滚动条滚动到底了
当满足scrollWidth - scrollLeft = clientWidth
说明水平滚动条滚动到底
如果为表单项添加disabled= "disabled"则表单项将变成不可用的状态
当垂直滚动条滚动到底时使表单项可用
onscroll
该事件会在元素的滚动条滚动时触发
用户注册手册例子
(当滚动条到达底部才允许勾选和注册)
//获取id为info的p元素
var info = document.getElementById("info");
//获取两个表单项
var inputs = document.getElementByTayName("input");
//为info绑定一个滚动条滚动的事件
info.onscroll = function(){
//检查垂直滚动条是否滚动到底
if(info.scrollHeight - info.scrollTop == info.clientHeight ){
//滚动条滚动到底,使表单项可用
/*
disabled属性可以设置一个元素是否禁用,
如果设置为true,则元素禁用
如果设置为false,则元素可用
*/
inputs[0].disabled = false;
inputs[1].disabled = false;
}
};
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!