JS中的DOM操作

JS中的DOM操作

JS中的DOM操作主要可以改变网页中的内容,结构(标签),属性以及样式.

同样这些操作针对于DOM而言也是通过操作对象的属性来实现的

改变元素中的内容

  • 对于文本框元素而言,其内容属于value属性的值
  • 对于其它标签内容指的是写在两个标签之间的内容部分,所以无法使用value属性实现

为了解决这个问题我们使用两个节点对象属性

  • 元素的innerText属性
  • 元素的innerHTML属性

这两个属性都可以修改一个节点之间的内容

注意:

对于HTML文件而言能够识别<>,如果内容里面有<>,则对于HTML文件而言可能会将这个内容字符串里面的<>当成标签处理

两者之间的区别

innerText
  • innerText在获取内容操作时,不会将内部的标签进行字符串处理,不会获取标签
  • innerText在设置内容时,会将字符串直接输出到页面不会解析内容中的<>,并且会保留字符串内的空格以及换行.
innerHTML
  • innerHTML在获取内容操作时,会将其内部的所有标签及内容全部进行字符串处理并返回
  • innerHTML在设置内容时,会将字符串里面的"<>"进行解析然后再体现到页面中,不会保留字符串内的空格及换行。

实例

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

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>DOM操作之改变文本内容</title>
    <style>
    </style>
</head>

<body>
    <input type="text" value="请输入一个内容" id="txt">
    <h3 id="myh3"><u>改变之前的内容1</u></h3>
    <h2 id="myh2"><u>改变之前的内容2</u></h2>
    <b id="myb">a</b>
    <script>
        window.onload = function () {
     
     
            var txt = document.getElementById("txt");
            txt.onmousedown = function () {
     
     
                txt.value = "改变之后";
            }

            var h3 = document.querySelector("#myh3");
            h3.onmousedown = function () {
     
     
                h3.innerText = "改变之后1";
            }

            var h2 = document.querySelector("#myh2");
            h2.onmousedown = function () {
     
     
                h2.innerHTML = "改变之后2";
            }

            var b = document.getElementById("myb");
            b.onmousedown = function () {
     
     
                b.innerHTML = "<u>这是下划线</u>";
            }
        }
    </script>
</body>

</html>

改变元素的样式

可以用DOM操作获取到元素对象之后,同时可以使用JS对元素的样式(大小,颜色,位置等)进行操作

常用方式

  • element.style开始对style(样式)的内容进行操作
  • element.className通过对类名进行样式操作

通过style属性操作样式

  • 元素对象的style属性也是一个对象
  • 通过对元素的style进行样式属性=值
  • JS里面样式命名方式采取的是驼峰命名法
  • JS修改style样式操作,产生的是行内样式,CSS权重较高

通过操作className属性

  • 元素对象.className=值,使用className并非class,因为JS里面的class是特殊关键字
  • 如果样式修改的比较多,利用这样方式修改更为方便
  • className会直接更改元素的class属性的内容,会覆盖原始的class值,如果不想覆盖的话使用多类名即可

实例

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

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>鼠标移入表格一行换色</title>
    <style>
        * {
     
     
            margin: 0px;
            padding: 0px;
        }

        table tr td {
     
     
            border: 1px solid red;
            text-align: center;
        }

        table {
     
     
            margin: 100px auto;
            width: 400px;
            height: 400px;
            border-collapse: collapse;
        }
    </style>
</head>

<body>
    <table>
        <tr>
            <td>
                红米
            </td>
            <td>
                5900元
            </td>
        </tr>
        <tr>
            <td>
                华为
            </td>
            <td>
                9999元
            </td>
        </tr>
        <tr>
            <td>
                小米
            </td>
            <td>
                2000元
            </td>
        </tr>
        <tr>
            <td>
                vivo
            </td>
            <td>
                100元
            </td>
        </tr>
    </table>
    <script>
        window.onload = function () {
     
     
            var a = document.querySelectorAll("table tr")
            for (var i = 0; i < a.length; i++) {
     
     
                a[i].onmouseover = function () {
     
     
                    for (var j = 0; j < a.length; j++) {
     
     
                        a[j].style.backgroundColor = "white";
                    }
                    this.style.backgroundColor = "orange";
                }
                a[i].onmouseout = function () {
     
     
                    for (var j = 0; j < a.length; j++) {
     
     
                        a[j].style.backgroundColor = "white";
                    }
                    b.style.display = "none";
                }
            }
        }
    </script>
</body>

</html>

猜你喜欢

转载自blog.csdn.net/XVJINHUA954/article/details/111564273
今日推荐