学习js的第十天:DOM文档对象模型

一、DOM文档对象模型

1.作用:提供操作html文档,html标签元素的能力

2.document文档对象,直接使用window.document

3.属性和方法:

方法:

1.获取标签元素的方法:

1>getElementById('id属性值')

<h2 id="title">DOM学习</h2>
function test(){
 var h2Ele=document.getElementById('tilte')
 console.log(h2Ele)
}test()

 2>getElementByclassName('id属性值')

返回的是一个类数组(伪数组),不能使用Array的常用方法,但可以遍历。

<div class="title">DOM学习</div>
    <script>
        function test() {
            var divEle = document.getElementsByClassName('title')
            
            for(var i=0;i<divEle.length;i++){
                console.log('divEle[i]:',divEle[i])
            }
        }
        test()
    </script>

3>getElementsByTagName('标签名')

因为页面中可能有多个元素的标签名称一样,所有获取到的是一组元素

<div>DOM学习</div>
    <script>
        function test() {
            var divEle = document.getElementsByTagName('div')
            
            for(var i=0;i<divEle.length;i++){
                console.log('divEle[i]:',divEle[i])
            }
        }
        test()
    </script>

4>getElementsByName('name属性')

2.querySelector 和 querySelectorAll

1>querySelector类型

 <h2 id="title">DOM学习</h2>
    <script>
        function test() {
            var h2Ele = document.querySelector('#title')
            
                console.log('h2Ele:',h2Ele)
        }
        test()
    </script>

 2>querySelectorAll类型

这个方法能获取到所有满足条件的元素,是以一个伪数组的形式返回

 3.操作内容:

1.>获取元素内部的HTML结构 : 元素.innerHTML

2.>设置元素内容 : 元素.innerHTML='新内容'

列题 :

<!DOCTYPE html>
<html>

<head lang="en">
    <meta charset="UTF-8">
    <title>操作内容示例</title>
    <style type="text/css">
        body,
        input,
        div,
        p {
            margin: 0;
            padding: 0;
        }

        body {
            font-size: 14px;
            font-family: "微软雅黑";
            line-height: 25px;
        }

        .content {
            width: 550px;
            margin: 0 auto;
        }

        .content img {
            float: left;
            width: 150px;
        }

        .r {
            float: left;
            width: 400px;
        }

        input[name="changeBook"] {
            width: 100px;
            height: 28px;
            line-height: 28px;
            text-align: center;
            font-size: 14px;
            font-family: "微软雅黑";
            margin: 10px 0 10px 0;
        }

        input[name="season"] {
            width: 50px;
            text-align: center;
        }

        .input {
            border: 1px solid green;
            font-size: 18px;
            font-weight: bold;
        }
    </style>
</head>

<body>
    <div class="content">
        <img src="images/book.jpg" alt="岛上书店" />
        <div class="r">
            <div id="book">书名:岛上书店</div>
            <input id="updatename" name="changeBook" value="换换名称" type="button"
             onclick="onUpdateBookName()" /><br>

            四季名称:
            <input name="season" type="text" value="春" />
            <input name="season" type="text" value="夏" />
            <input name="season" type="text" value="秋" />
            <input name="season" type="text" value="冬" /><br><br>

            <input name="b2" type="button" value="input内容" onclick="onShowInput()" />

            <input name="b3" type="button" value="四季名称" onclick="onSeason()" />
            <input name="b4" type="button" value="清空页面内容" onclick="onClear()" />
            <p id="replace"></p>
        </div>
    </div>
    <script type="text/javascript">
        /*
          做什么?
            点击换换名称按钮,更换书名
            1. 绑定点击事件
            2. 更改名内容
        */
        function onUpdateBookName() {
         var divEle=document.querySelector('#book')
         divEle.innerHTML='书名:哈哈哈哈哈'
         console.log(divEle.innerHTML)
        }

        /*
          做什么?
            点击input内容按钮,将所有input按钮内容值拼接成字符串设置给p标签作为内容显示
            1. input内容按钮点击事件
            2. 将所有input标签内容值拼接成字符串
                 
            3. 操作p标签内容
        
        */
        function onShowInput() {
            var inputEle = document.querySelectorAll('input') 
            var str=''
            inputEle.forEach(function(item){ 
               str = str + item.value
            })
            console.log(str)
            var pEle=document.querySelector('p')
            pEle.innerHTML=str
            
           
        }
        /*
           做什么?
             点击四季名称按钮,拼接四季名称显示

        */
        function onSeason() {
          var inputContent=document.querySelectorAll('input[name="season"]')
          var str=''
          inputContent.forEach(function(item){
            str=str+item.value
          })
          var pEle=document.querySelector('p')
            pEle.innerHTML=str
        
        }

        function onClear() {
            document.write('')
        }

    </script>
</body>

</html>

3>innerText获取元素内部的文本(只能获取到文本内容,获取不到html标签)

可以设置元素的内部文本

会把<p>hello</p>当作一个文本出现在div元素里面,而不会把p解析成标签

 value:操作表单元素 ==》表单的内容

 <input type="text">
    <script>
        function test() {
            var inputEle = document.querySelector('input')
            inputEle.value='哈哈哈'
            console.log(inputEle.value)
        }
        test()
    </script>

 操作样式:

使用js代码动态操作样式

1.获取行内样式style:ele.style.样式名

 <h2 style="color: red;">hhhhhhh</h2>
    <script>
        function test() {
            var h2Ele=document.querySelector('h2')
            console.log(h2Ele.style.color)

        }
        test()
    </script>

2.设置样式:ele.style.样式名='要设置的值'

 <h2 style="color: red;">hhhhhhh</h2>
    <script>
        function test() {
            var h2Ele=document.querySelector('h2')
            h2Ele.style.color='green'
            console.log(h2Ele.style.color)

        }
        test()
    </script>

3.类样式:ele.className='类名'

注:后面的类名会覆盖前面的

<div class="box"></div>
    <script>
        function test() {
            var div=document.querySelector('div')
            console.log(div.className)

        }
        test()
    </script>

两个元素的情况:ele.classList.add(类名1)

                             ele.classList.add(类名2)

获取类样式:ele.getComputedStyle(元素).样式名

  <style>
        h3{
            width: 100px;
        }
    </style>
 <h3 class="box"></h3>
    <script>
        function test() {
            var h3Ele=document.querySelector('h3')
            console.log(window.getComputedStyle(h3Ele).width)

        }
        test()
    </script>

操作属性:

通过js代码动态获取属性或设置属性值

1.获取属性值:

1>ele.getAttribute('属性名')包括自定义属性

 <h3 id="box" a="active"></h3>
    <script>
        function test() {
            var h3Ele=document.querySelector('h3')
            var idEle=h3Ele.getAttribute('id')
            var idEle1=h3Ele.getAttribute('a')
            console.log(idEle,idEle1)

        }
        test()
    </script>

 2>针对自身有的属性:ele.属性值

 <img src="http//"></img>
    <script>
        var imgEle=document.querySelector('img')
        console.log(imgEle.src)
    </script>

2.设置属性:

1>ele.setAttribute('属性名',"属性值")

<h3></h3>
    <script>
        function test() {
            var h3Ele=document.querySelector('h3')
            h3Ele.setAttribute('id','title')
            console.log(h3Ele)

        }
        test()
    </script>

2>ele.属性名=属性值

3.删除属性:ele.removeAttribute('属性名')

4.自定义属性:data-属性名  ==>获取属性值:ele.dataset.属性名

<h4 data-index="1001"></h4>
    <script>
        function test() {
            var h4Ele=document.querySelector('h4')
            var b=h4Ele.dataset.index
            console.log(b)
        }
        test()
    </script>

 操作事件:

1.给元素绑定点击事件,直接给元素添加onclick属性实现属性事件

 <style>
        div{
            width: 100px;
            height: 100px;
        }
    </style>
<div></div>
    <button onclick="test()">按钮</button>
    <script>
        function test() {
            var div=document.querySelector('div')
            div.style.backgroundColor='pink'

        }
    </script>

 2.元素和事件行为分离

 <div></div>
    <button>按钮</button>
    <script>
        function test() {
            var btn=document.querySelector('button')
            var div=document.querySelector('div')
            btn.onclick=function(){
                div.style.backgroundColor='pink'

            }

        }test()
    </script>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: HTML DOM文档对象模型)是一种编程接口,允许程序访问和操作HTML文档中的元素。使用JavaScript来操作HTML DOM可以让网页具有交互性和动态性。 在JavaScript中,可以使用getElementById,getElementsByTagName和getElementsByClassName等方法来获取页面上的元素。例如,通过getElementById("myId")可以获取id为"myId"的元素。 操作元素的属性和内容也很简单,可以使用如下方法: - 修改元素的属性:element.attribute = new value - 访问元素的属性:element.attribute - 修改元素的内容:element.innerHTML = new content - 访问元素的内容:element.innerHTML 通过操作HTML DOM,可以实现各种交互效果和动态效果。例如,可以在点击按钮时显示或隐藏元素,或在输入框中输入文本时实时更新页面内容等。 ### 回答2: HTML DOM是JavaScript操作网页中元素和属性的主要方式之一。在HTML DOM中,文档元素是指HTML页面中所有元素的根节点。文档元素的操作包括获取元素、创建元素、删除元素、修改元素属性等。 获取元素是HTML DOM操作的重要一环。在JavaScript中,可以使用getElementById()、getElementsByTagName()、getElementsByClassName()等方法获得HTML页面中的元素。其中getElementById()方法可以通过元素的ID获取该元素的引用,常用于根据ID修改元素的属性或内容。而getElementsByTagName()方法可以通过标签名获取HTML页面中所有该标签的元素,例如获取所有的h1元素,常用于对整个页面的控制。getElementsByClassName()方法可以通过class属性获取HTML页面中所有具有该class的元素。 创建元素是向HTML页面中添加元素的重要方式。可以使用createElement()方法创建一个新元素,然后使用appendChild()方法将其添加到现有元素中。例如,创建一个新的p元素,并将其添加到body元素中可以使用以下代码: var newPara = document.createElement("p"); var textNode = document.createTextNode("This is a new paragraph."); newPara.appendChild(textNode); document.body.appendChild(newPara); 删除元素也是HTML DOM中的一个常用操作。可以使用removeChild()方法删除现有元素,例如: var parent = document.getElementById("parent-id"); var child = document.getElementById("child-id"); parent.removeChild(child); 修改元素属性是HTML DOM中的另一个核心操作。可以使用setAttribute()方法修改元素的属性值,例如: var element = document.getElementById("my-id"); element.setAttribute("class", "new-class"); 可以通过HTML DOM操作文档元素,实现对页面元素和属性的各种操作。掌握HTML DOM的知识,可以更好地控制和管理HTML页面。 ### 回答3: HTML DOM是JavaScript操作网页元素的主要方式之一,它的核心在于文档对象模型DOM,Document Object Model),需要熟悉DOM才能灵活操作网页元素。文档元素是HTML页面中的根元素,它是其他所有元素的祖先元素,也是HTML DOM操作的基础。 一、获取元素 在JavaScript中,我们可以通过各种方式来获取文档元素,例如getElementById()、getElementsByTagName()、getElementsByClassName()等。其中,通过id、标签名和类名获取元素是最常用的三种方法。 1. getElementById() 此方法用于获取具有指定id属性的元素,其语法为document.getElementById(id)。id属性在整个HTML文档中应该是唯一的。 示例:获取id为“demo”的元素 ``` var demo = document.getElementById("demo”); ``` 2. getElementsByTagName() 此方法用于获取具有指定标签名的元素,其语法为document.getElementsByTagName(tagname)。 示例:获取所有p元素 ``` var pList = document.getElementsByTagName("p"); ``` 3. getElementsByClassName() 此方法用于获取具有指定类名的元素,其语法为document.getElementsByClassName(classname)。 示例:获取类名为“red”的元素 ``` var redList = document.getElementsByClassName("red"); ``` 二、改变元素 有很多种方法可以改变文档元素的属性和样式,下面列举一些常见的方法: 1. 修改元素的文本内容 我们可以通过innerHTML属性和innerText属性来修改元素的文本内容。 innerHTML属性用于改变元素的HTML内容,其语法为element.innerHTML=new html content; innerText属性用于改变元素的纯文本内容,其语法为element.innerText=new text content; 2. 修改元素的样式 我们可以通过style属性来修改元素的样式,其中style属性包含了元素的所有样式属性。 示例:将id为“demo”的元素背景色改为红色 ``` document.getElementById("demo").style.backgroundColor = "red"; ``` 3. 创建新元素 我们可以使用document.createElement()方法来创建新元素,并通过appendChild()方法将其加入到指定的元素内。 示例:创建一个新的p元素 ``` var newP = document.createElement("p"); ``` 4. 删除元素 我们可以使用parentNode.removeChild()方法来删除指定的元素。 示例:删除id为“demo”的元素 ``` var demo = document.getElementById("demo"); demo.parentNode.removeChild(demo); ``` 三、总结 通过这篇文章的学习,我们了解了HTML DOM的基础知识和基本操作方法,例如获取元素、改变元素的属性和样式以及创建和删除元素等。掌握这些操作方法可以帮助我们更好地操作网页元素,从而实现丰富多彩的网页效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值