使用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;
 }
};
posted @ 2022-02-05 17:30  苏槿年  阅读(428)  评论(0编辑  收藏  举报