• w3school 在线教程:https://www.w3school.com.cn
  1. JavaScript学习笔记01【基础——简介、基础语法、运算符、特殊语法、流程控制语句】【day01】
  2. JavaScript学习笔记02【基础——对象(Function、Array、Date、Math、RegExp、Global)】【day01】
  3. JavaScript学习笔记03【基础——对象(RegExp、Global)】【day01】
  4. JavaScript学习笔记04【高级——DOM和事件的简单学习、BOM对象】【day02】
  5. JavaScript学习笔记05【高级——DOM对象】【day02】
  6. JavaScript学习笔记06【高级——JavaScript中的事件】【day02】

目录

09 DOM对象

DOM_概述

HTML DOM树

DOM、XML DOM、HTML DOM

DOM_Document对象_获取Element

XML DOM Document 对象

DOM_Document对象_创建DOM

DOM_Element对象

DOM_Node对象

XML DOM - Node 对象

案例4_动态表格_添加

案例4_动态表格_删除

HTML_DOM_innerHTML

案例4_动态表格——innerHTML简写版

HTML_DOM_样式控制


09 DOM对象

DOM_概述

* 概念: Document Object Model 文档对象模型
    * 将标记语言文档的各个组成部分,封装为对象。可以使用这些对象,对标记语言文档进行CRUD的动态操作。

* W3C DOM 标准被分为 3 个不同的部分:

* 核心 DOM - 针对任何结构化文档的标准模型
        * Document:文档对象
        * Element:元素对象
        * Attribute:属性对象
        * Text:文本对象
        * Comment:注释对象

* Node:节点对象,其他5个的父对象
    * XML DOM - 针对 XML 文档的标准模型
    * HTML DOM - 针对 HTML 文档的标准模型
* 核心DOM模型:
    * Document:文档对象
    * Element:元素对象
    * Node:节点对象,其他5个的父对象
* HTML DOM

HTML DOM树

DOM、XML DOM、HTML DOM

DOM_Document对象_获取Element

Document:文档对象
    1. 创建(获取):在html dom模型中可以使用window对象来获取
        1. window.document
        2. document
    2. 方法:
        1. 获取Element对象:
            1. getElementById():根据id属性值获取元素对象。id属性值一般唯一。
            2. getElementsByTagName():根据元素名称获取元素对象们。返回值是一个数组。
            3. getElementsByClassName():根据Class属性值获取元素对象们。返回值是一个数组。
            4. getElementsByName():根据name属性值获取元素对象们。返回值是一个数组。
        2. 创建其他DOM对象
    3. 属性

XML DOM Document 对象

XML DOM、HTML DOM 是 “核心 DOM”的拓展。学习 核心DOM模型,需要查看XML DOM,因为 HTML DOM 对 “核心 DOM” 做的修改 较多。

DOM_Document对象_创建DOM

Document:文档对象
    1. 创建(获取):在html dom模型中可以使用window对象来获取
        1. window.document
        2. document
    2. 方法:
        1. 获取Element对象:
            1. getElementById():根据id属性值获取元素对象。id属性值一般唯一。
            2. getElementsByTagName():根据元素名称获取元素对象们。返回值是一个数组。
            3. getElementsByClassName():根据Class属性值获取元素对象们。返回值是一个数组。
            4. getElementsByName():根据name属性值获取元素对象们。返回值是一个数组。
        2. 创建其他DOM对象:
            createAttribute(name)
            createComment()
            createElement()
            createTextNode()
    3. 属性

DOM_Element对象

* 核心DOM模型:
    * Element:元素对象
        1. 获取/创建:通过document来获取和创建
        2. 方法:
            1. removeAttribute():删除属性
            2. setAttribute():设置属性

  

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>Element对象</title></head><body><a>点我试一试</a><input type="button" id="btn_set" value="设置属性"><input type="button" id="btn_remove" value="删除属性"><script>//获取btnvar btn_set = document.getElementById("btn_set");btn_set.onclick = function() {//1.获取a标签var element_a = document.getElementsByTagName("a")[0];element_a.setAttribute("href", "https://www.baidu.com");}//获取btnvar btn_remove = document.getElementById("btn_remove");btn_remove.onclick = function() {//1.获取a标签var element_a = document.getElementsByTagName("a")[0];element_a.removeAttribute("href");}</script></body>
</html>

DOM_Node对象

* 核心DOM模型:
    * Node:节点对象,其他5个的父对象。
        * 特点:所有dom对象都可以被认为是一个节点。
        * 方法:
            * CRUD dom树:
                * appendChild():向节点的子节点列表的结尾添加新的子节点。
                * removeChild():删除(并返回)当前节点的指定子节点。
                * replaceChild():用新节点替换一个子节点。
        * 属性:
            * parentNode:返回节点的父节点。

 

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>Node对象</title><style>div {border: 1px solid red;}#div1 {width: 200px;height: 200px;}#div2 {width: 100px;height: 100px;}#div3 {width: 100px;height: 100px;}</style></head><body><div id="div1"><div id="div2">div2</div>div1</div><a href="javascript:void(0);" id="del">删除子节点</a><a href="javascript:void(0);" id="add">添加子节点</a><!--<input type="button" id="del" value="删除子节点">--><script>//1.获取超链接var element_a = document.getElementById("del");//2.绑定单击事件element_a.onclick = function() {var div1 = document.getElementById("div1");var div2 = document.getElementById("div2");div1.removeChild(div2);}//1.获取超链接var element_add = document.getElementById("add");//2.绑定单击事件element_add.onclick = function() {var div1 = document.getElementById("div1");//给div1添加子节点//创建div节点var div3 = document.createElement("div");div3.setAttribute("id", "div3");div1.appendChild(div3);}/*超链接功能:1.可以被点击:样式2.点击后跳转到href指定的url需求:保留1功能,去掉2功能实现:href="javascript:void(0);"*/var div2 = document.getElementById("div2");var div1 = div2.parentNode;alert(div1); // [object HTMLDivElement]</script></body>
</html>

XML DOM - Node 对象

案例4_动态表格_添加

分析:
    1.添加:
        1. 给添加按钮绑定单击事件
        2. 获取文本框的内容
        3. 创建td,设置td的文本为文本框的内容。
        4. 创建tr
        5. 将td添加到tr中
        6. 获取table,将tr添加到table中

  

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>动态表格</title><style>table {border: 1px solid;margin: auto;width: 500px;}td, th {text-align: center;border: 1px solid;}div {text-align: center;margin: 50px;}</style>
</head>
<body><div><input type="text" id="id" placeholder="请输入编号"><input type="text" id="name" placeholder="请输入姓名"><input type="text" id="gender" placeholder="请输入性别"><input type="button" value="添加" id="btn_add"></div><table><caption>学生信息表</caption><tr><th>编号</th><th>姓名</th><th>性别</th><th>操作</th></tr><tr><td>1</td><td>令狐冲</td><td>男</td><td><a href="javascript:void(0);" onclick="delTr(this);">删除</a></td></tr><tr><td>2</td><td>任我行</td><td>男</td><td><a href="javascript:void(0);" onclick="delTr(this);">删除</a></td></tr><tr><td>3</td><td>岳不群</td><td>?</td><td><a href="javascript:void(0);" onclick="delTr(this);">删除</a></td></tr></table><script>//1.获取按钮document.getElementById("btn_add").onclick = function () {//2.获取文本框的内容var id = document.getElementById("id").value;var name = document.getElementById("name").value;var gender = document.getElementById("gender").value;//3.创建td,赋值td的标签体//id 的 tdvar td_id = document.createElement("td");var text_id = document.createTextNode(id);td_id.appendChild(text_id);//name 的 tdvar td_name = document.createElement("td");var text_name = document.createTextNode(name);td_name.appendChild(text_name);//gender 的 tdvar td_gender = document.createElement("td");var text_gender = document.createTextNode(gender);td_gender.appendChild(text_gender);//a标签的tdvar td_a = document.createElement("td");var ele_a = document.createElement("a");ele_a.setAttribute("href", "javascript:void(0);");ele_a.setAttribute("onclick", "delTr(this);");var text_a = document.createTextNode("删除");ele_a.appendChild(text_a);td_a.appendChild(ele_a);//4.创建trvar tr = document.createElement("tr");//5.添加td到tr中tr.appendChild(td_id);tr.appendChild(td_name);tr.appendChild(td_gender);tr.appendChild(td_a);//6.获取tablevar table = document.getElementsByTagName("table")[0];table.appendChild(tr);}</script>
</body>
</html>

案例4_动态表格_删除

分析:
    1.添加:
        1. 给添加按钮绑定单击事件
        2. 获取文本框的内容
        3. 创建td,设置td的文本为文本框的内容。
        4. 创建tr
        5. 将td添加到tr中
        6. 获取table,将tr添加到table中
    2.删除:
        1.确定点击的是哪一个超链接
            <a href="javascript:void(0);" οnclick="delTr(this);" >删除</a>
        2.怎么删除?
            removeChild():通过父节点删除子节点

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>动态表格</title><style>table {border: 1px solid;margin: auto;width: 500px;}td, th {text-align: center;border: 1px solid;}div {text-align: center;margin: 50px;}</style></head><body><div><input type="text" id="id" placeholder="请输入编号"><input type="text" id="name" placeholder="请输入姓名"><input type="text" id="gender" placeholder="请输入性别"><input type="button" value="添加" id="btn_add"></div><table><caption>学生信息表</caption><tr><th>编号</th><th>姓名</th><th>性别</th><th>操作</th></tr><tr><td>1</td><td>令狐冲</td><td>男</td><td><a href="javascript:void(0);" onclick="delTr(this);">删除</a></td></tr><tr><td>2</td><td>任我行</td><td>男</td><td><a href="javascript:void(0);" onclick="delTr(this);">删除</a></td></tr><tr><td>3</td><td>岳不群</td><td>?</td><td><a href="javascript:void(0);" onclick="delTr(this);">删除</a></td></tr></table><script>//1.获取按钮document.getElementById("btn_add").onclick = function() {//2.获取文本框的内容var id = document.getElementById("id").value;var name = document.getElementById("name").value;var gender = document.getElementById("gender").value;//3.创建td,赋值td的标签体//id 的 tdvar td_id = document.createElement("td");var text_id = document.createTextNode(id);td_id.appendChild(text_id);//name 的 tdvar td_name = document.createElement("td");var text_name = document.createTextNode(name);td_name.appendChild(text_name);//gender 的 tdvar td_gender = document.createElement("td");var text_gender = document.createTextNode(gender);td_gender.appendChild(text_gender);//a标签的tdvar td_a = document.createElement("td");var ele_a = document.createElement("a");ele_a.setAttribute("href", "javascript:void(0);");ele_a.setAttribute("onclick", "delTr(this);");var text_a = document.createTextNode("删除");ele_a.appendChild(text_a);td_a.appendChild(ele_a);//4.创建trvar tr = document.createElement("tr");//5.添加td到tr中tr.appendChild(td_id);tr.appendChild(td_name);tr.appendChild(td_gender);tr.appendChild(td_a);//6.获取tablevar table = document.getElementsByTagName("table")[0];table.appendChild(tr);}//删除方法function delTr(obj) {//this代表当前超链接对象//obj.parentNode:td;var tr = obj.parentNode.parentNode;var table = obj.parentNode.parentNode.parentNode;table.removeChild(tr);}</script></body>
</html>

HTML_DOM_innerHTML

案例4_动态表格——innerHTML简写版

* HTML DOM
    1. 标签体的设置和获取:innerHTML
    2. 使用html元素对象的属性
    3. 控制元素样式

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>动态表格</title><style>table {border: 1px solid;margin: auto;width: 500px;}td, th {text-align: center;border: 1px solid;}div {text-align: center;margin: 50px;}</style></head><body><div><input type="text" id="id" placeholder="请输入编号"><input type="text" id="name" placeholder="请输入姓名"><input type="text" id="gender" placeholder="请输入性别"><input type="button" value="添加" id="btn_add"></div><table><caption>学生信息表</caption><tr><th>编号</th><th>姓名</th><th>性别</th><th>操作</th></tr><tr><td>1</td><td>令狐冲</td><td>男</td><td><a href="javascript:void(0);" onclick="delTr(this);">删除</a></td></tr><tr><td>2</td><td>任我行</td><td>男</td><td><a href="javascript:void(0);" onclick="delTr(this);">删除</a></td></tr><tr><td>3</td><td>岳不群</td><td>?</td><td><a href="javascript:void(0);" onclick="delTr(this);">删除</a></td></tr></table><script>//使用innerHTML添加document.getElementById("btn_add").onclick = function() {//获取文本框的内容var id = document.getElementById("id").value;var name = document.getElementById("name").value;var gender = document.getElementById("gender").value;//获取tablevar table = document.getElementsByTagName("table")[0];//追加一行table.innerHTML += "<tr>\n" +"        <td>" + id + "</td>\n" +"        <td>" + name + "</td>\n" +"        <td>" + gender + "</td>\n" +"        <td><a href=\"javascript:void(0);\" onclick=\"delTr(this);\" >删除</a></td>\n" +"    </tr>";}//删除方法function delTr(obj) {//this代表当前超链接对象//obj.parentNode:td;var tr = obj.parentNode.parentNode;var table = obj.parentNode.parentNode.parentNode;table.removeChild(tr);}</script></body>
</html>

HTML_DOM_样式控制

* HTML DOM
    1. 标签体的设置和获取:innerHTML
    2. 使用html元素对象的属性
    3. 控制元素样式
        1. 使用元素的style属性来设置
            如:
                //修改样式方式1
                div1.style.border = "1px solid red";
                div1.style.width = "200px";
                //font-size--> fontSize
                div1.style.fontSize = "20px";
        2. 提前定义好类选择器的样式,通过元素的className属性来设置其class属性值。

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>控制样式</title><style>.d1 {border: 1px solid red;width: 100px;height: 100px;}.d2 {border: 1px solid blue;width: 200px;height: 200px;}</style></head><body><div id="div1">div1</div><div id="div2">div2</div><script>var div1 = document.getElementById("div1");div1.onclick = function() {//修改样式方式1div1.style.border = "1px solid red";div1.style.width = "200px";//font-size --> fontSizediv1.style.fontSize = "20px";}var div2 = document.getElementById("div2");div2.onclick = function() {div2.className = "d1";}</script></body>
</html>

加油~

JavaScript学习笔记05【高级——DOM对象】相关推荐

  1. JavaScript学习笔记02【基础——对象(Function、Array、Date、Math)】

    w3school 在线教程:https://www.w3school.com.cn JavaScript学习笔记01[基础--简介.基础语法.运算符.特殊语法.流程控制语句][day01] JavaS ...

  2. JavaScript学习笔记03【基础——对象(RegExp、Global)】

    w3school 在线教程:https://www.w3school.com.cn JavaScript学习笔记01[基础--简介.基础语法.运算符.特殊语法.流程控制语句][day01] JavaS ...

  3. JavaScript学习笔记03-数组-Data对象-Math对象-包装类-字符串-正则

    目录 一.数组 索引 数组的特点 1.1.数组的创建 1.1.1.使用new关键字(构造函数) 1.1.2.使用字面量形式 1.1.3.创建数组的注意事项 1.2.数组的基本使用 1.2.1.存操作( ...

  4. JavaScript学习笔记系列2:Dom操作(一)

    一.什么是Dom? DOM------>Document Object Model 直接翻译就是文档对象模型. DOM------>定义了表示和修改文档所需的对象.这些对象的行为和属性以及 ...

  5. JavaScript学习笔记 06、DOM元素—③定时器与延时器

    文章目录 前言 一.定时器(√) 1.1.介绍定时器与清除定时器方法(含案例) 1.2.解决按钮点击时设置定时器setInterval()的小问题 1.3.实际案例(设置与删除定时器) 二.延时器(√ ...

  6. JavaScript学习笔记:创建自定义对象

    文章目录 一.利用构造函数模式创建自定义对象 二.采用原型模式创建自定义对象 三.采用混合模式创建自定义对象 四.采用动态原型模式创建自定义对象 一.利用构造函数模式创建自定义对象 使用构造函数可以创 ...

  7. Javascript学习笔记——JSON:js对象简谱

    Javascript不仅是一种编程语言,还被作为一种常用的对象存储和传输格式 JSON:JS 对象简谱 JSON(JavaScript Object Notation)即Javascript对象简谱 ...

  8. JavaScript学习笔记04【高级——DOM和事件的简单学习、BOM对象】

    w3school 在线教程:https://www.w3school.com.cn JavaScript学习笔记01[基础--简介.基础语法.运算符.特殊语法.流程控制语句][day01] JavaS ...

  9. JavaScript学习笔记06【高级——JavaScript中的事件】

    w3school 在线教程:https://www.w3school.com.cn JavaScript学习笔记01[基础--简介.基础语法.运算符.特殊语法.流程控制语句][day01] JavaS ...

最新文章

  1. Java项目:诚途旅游系统(java+JSP+Spring+SSM+Mysql)
  2. 【Django】创建项目及框架介绍,学习笔记(一)
  3. i27岁转行java,JavaTM I/O 性能分析[转]
  4. 【转】Impala导出查询结果到文件
  5. 最新阿里内推Java后端面试题
  6. MySQL删库数据延迟恢复策略
  7. 《当程序员的那些狗日日子》(三十四)人事变动
  8. APP打开直接显示图片,去掉中间的白屏时间
  9. PCM设备的作用,为什么要选用PCM设备?
  10. hadoopsdk使用_hadoop部署使用问题及解决
  11. php绘制频谱图,一步一步教你实现iOS音频频谱动画(二)
  12. mysql clickhouse_通过mysql操作clickhouse
  13. Loadrunner2021安装教程
  14. FS4054单节锂电池充电管理芯片,IC电路图
  15. JAVA之父----詹姆斯.高斯林
  16. 一张图了解致远A6人事管理
  17. Snapchat面试题:移除K位
  18. wi7计算机桌面删除,win7系统删除桌面右键多余选项
  19. CSS笔试题: 实现表格首行首列固定和自适应窗口
  20. STM32初学——OLED调试4-1 5-1/5-2

热门文章

  1. Navicat mysql 加索引_mysql 索引 (Navicat添加索引)
  2. 中英文怎么算 字符长度_钢材长度怎么算,只有1%的人才懂!
  3. 自然语言处理美国政客的社交媒体消息分类
  4. Tomcat 初始化端点错误--Error initializing endpoint
  5. 从ICLR 2022看什么是好的图神经网络?
  6. BERT在文档级排序中的应用
  7. 最新综述:推荐系统的Bias问题和Debias方法
  8. CVPR 2020 Oral | 无域标签下高清场景时移变换
  9. PW Live 直播 | 清华大学王晓智:事件抽取的进展与挑战
  10. EMNLP2018论文解读 | 三种提升多语言翻译模型的高效策略