Js的三大核心之DOM

 

 

dom   获取dom元素、修改属性

 作用:就是使用js去操作html和浏览器

dom(文档对象模型) bom(浏览器对象模型)

 什么是dom?

dom是 document object model------文档对象模型     是用来呈现以及任意html或xml文档监护的api

dom是浏览器提供的一套专门用来操作网页内容的功能

dom作用

开发网页内容特效和实现用户交互

bom树:

将html文档以树状结构直观的变现出来,我们称之为文档树或者dom树 

 dom对象:浏览器根据html标签生成的js对象

所有的标签属性都可以在这个对象(dom对象)上面找到

修改这个对象的属性会自动映射到标签身上

 把网页内容当做对象来处理          网页里面的标签都可以当作对象来处理

 document对象

是dom里提供的一个对象

所以它提供的属性和方法都是用来访问和操作网页内容

例如:document.write()

网页所有内容都在document里面

 dom树

将html文档以树的形状直观的表现出来,我们称之为文档树或者dom树

作用:文档树直观的体现了标签与标签之间的关系

dom对象怎么创建的?

浏览器根据html标签生成的js对象(dom对象)

dom的核心就是把内容当作对象来处理

document:

是dom里面的一个对象

网页所有内容都在document里面

查找dom元素就是选择页面中标签的元素

 根据css选择器来获取dom元素(就是根据标签来获取dom元素)

 语法:document.querySelector( 'css选择器 ')    //可以是标签、class、id之类的css选择器

参数:

包含一个或者多个有效地css选择器字符串

返回值:

css选择器匹配的第一个元素,一格HTMLElement对象

如果没有匹配到,返回null

 选择匹配的多个元素

语法:

document.querySelectorAll('css选择器')

参数:

包含一个或者多个有效的css选择器字符串

返回值:

css选择器匹配的NodeList  对象集合

 获取一个dom元素我们使用:  querySelector()

获取多个dom元素使用:querySelectorAll()

querySelector()方法可以直接操作修改内容

querySelectorAll方法不能直接修改内容,只能先通过遍历的方式给里面的元素做修改

 哪怕只有一个元素,通过querySelectorAll()获取过来的也是一个伪数组,里面只有一个元素而已

 其他获取dom元素方法

根据id获取一个元素

document.getElementById(''nav)

根据 标签获取一类元素  获取页面 所有的div

document.getElementsByTagName('div')                           //Elements加上s的原因是所有的  +s

根据  类名获取元素  获取页面  所有类名为 w 的                //   //Elements加上s的原因是所有的  +s

document.getElementsByClassName('w')

 设置/修改DOM元素内容

document.write()方法

对象.innerText属性

对象.innerHTML属性

 只能将文本内容追加到<body>中的位置

文本中包含的标签会被解析

 元素innerText属性

将文本内容添加/更新到任意标签位置

文本中包含的标签不会被解析

 元素.innerHTML属性

将文本内容添加/更新到任意标签位置

文本中包含的标签会被解析

 

 设置/修改元素常用属性

还可以通过js设置/修改标签元素属性  比如通过src更换图片

最常见的属性:href 、title、src等

语法:

对象.属性 = 值

 还可以通过js设置/修改标签元素的样式属性(js控制样式)

1.通过style属性操作css

2.操作类名(classname)操作css

3.通过classList操作类控制css

 设置/修改元素样式属性

通过style属性操作css

对象.style.样式属性  = 值

 如果属性有 - 连接符,需要转换为小驼峰命名法

 操作类名(classname)修改css

如果修改的样式比较多,直接通过style属性修改比较麻烦,我们可以通过借助css类名的形式

元素.classNmae = 'active'

由于class 是关键字,所以使用className去代替

2. className 是使用新值旧值,如果需要添加一个类,需要保留之前的类名

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        body {
            background-image: url(./images/1.webp);
            /* background: no-repeat; */
        }
    </style>
</head>

<body>
    <script>
        // 随机函数
        function getRandom(min, max) {
            return Math.floor(Math.random() * (max - min + 1)) + min
        }

        let num = getRandom(1, 2)

        // 还是可以先获取元素   确定需要修改什么位置
        let beijing = document.querySelector(['body'])
        // 修改背景图片
        beijing.style.backgroundImage = `url(./images/${num}.webp)`
    </script>
</body>

</html>

 通过classList操作类控制css  重点

为了解决className容易覆盖以前的类名,我们可以通过classList方式追加和删除类名

语法:

追加一个类
元素.classList.add('类名')

删除一个类名

元素.classList.remove('类名')

切换一个类

元素.classList.toggle('类名')

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        div {
            width: 300px;
            height: 200px;
            background-color: aqua;
        }

        .active {
            width: 35px;
            height: 35px;
            background-color: pink;
            margin-left: 100px;
            margin-top: 100px;
        }
    </style>
</head>

<body>
    <div class="one"></div>


    <script>
        // 1获取对象
        let box = document.querySelector('div')   //获取这个标签对象

        // // 添加类  对象.classList.add   一次只能添加一个,如果添加多个将不会有效果
        // box.classList.add('active ')

        // // 删除类名       一次只能删除一个,如果删除多个将不会有效果
        // box.classList.remove('one')


        // 切换类     切换类就是原来的没有就添加,原来有这个类就删除掉
        box.classList.toggle('active')  //在这里原来是没有active这个类的,切换类就是添加上去
    </script>
</body>

</html>

 设置/修改  表单元素属性

 获取: dom对象.属性名

设置:dom对象.属性名 = 新值

 表单属性中添加就有效果,移除就没有效果,一律使用true代表添加了该属性,如果false代表移除了该属性。 

定时器--间歇函数

能够使用定时器函数重复执行代码

定时器函数可以开启和关闭定时器

 开启定时器:

setInterval(函数,间隔时间)

作用:每隔一段时间调用这个函数

间隔时间单位为毫秒

关闭定时器:   定时器需要关闭总不能程序一直执行下去!消耗性能,所以需要关闭
 

 定时器函数可以开启和关闭定时器

关闭定时器

let  变量名 = setInterval(函数,间隔时间)

clearInterval(变量名)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值