JavaScript学习笔记05【高级——DOM对象】
- w3school 在线教程:https://www.w3school.com.cn
- JavaScript学习笔记01【基础——简介、基础语法、运算符、特殊语法、流程控制语句】【day01】
- JavaScript学习笔记02【基础——对象(Function、Array、Date、Math、RegExp、Global)】【day01】
- JavaScript学习笔记03【基础——对象(RegExp、Global)】【day01】
- JavaScript学习笔记04【高级——DOM和事件的简单学习、BOM对象】【day02】
- JavaScript学习笔记05【高级——DOM对象】【day02】
- 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对象】相关推荐
- JavaScript学习笔记02【基础——对象(Function、Array、Date、Math)】
w3school 在线教程:https://www.w3school.com.cn JavaScript学习笔记01[基础--简介.基础语法.运算符.特殊语法.流程控制语句][day01] JavaS ...
- JavaScript学习笔记03【基础——对象(RegExp、Global)】
w3school 在线教程:https://www.w3school.com.cn JavaScript学习笔记01[基础--简介.基础语法.运算符.特殊语法.流程控制语句][day01] JavaS ...
- JavaScript学习笔记03-数组-Data对象-Math对象-包装类-字符串-正则
目录 一.数组 索引 数组的特点 1.1.数组的创建 1.1.1.使用new关键字(构造函数) 1.1.2.使用字面量形式 1.1.3.创建数组的注意事项 1.2.数组的基本使用 1.2.1.存操作( ...
- JavaScript学习笔记系列2:Dom操作(一)
一.什么是Dom? DOM------>Document Object Model 直接翻译就是文档对象模型. DOM------>定义了表示和修改文档所需的对象.这些对象的行为和属性以及 ...
- JavaScript学习笔记 06、DOM元素—③定时器与延时器
文章目录 前言 一.定时器(√) 1.1.介绍定时器与清除定时器方法(含案例) 1.2.解决按钮点击时设置定时器setInterval()的小问题 1.3.实际案例(设置与删除定时器) 二.延时器(√ ...
- JavaScript学习笔记:创建自定义对象
文章目录 一.利用构造函数模式创建自定义对象 二.采用原型模式创建自定义对象 三.采用混合模式创建自定义对象 四.采用动态原型模式创建自定义对象 一.利用构造函数模式创建自定义对象 使用构造函数可以创 ...
- Javascript学习笔记——JSON:js对象简谱
Javascript不仅是一种编程语言,还被作为一种常用的对象存储和传输格式 JSON:JS 对象简谱 JSON(JavaScript Object Notation)即Javascript对象简谱 ...
- JavaScript学习笔记04【高级——DOM和事件的简单学习、BOM对象】
w3school 在线教程:https://www.w3school.com.cn JavaScript学习笔记01[基础--简介.基础语法.运算符.特殊语法.流程控制语句][day01] JavaS ...
- JavaScript学习笔记06【高级——JavaScript中的事件】
w3school 在线教程:https://www.w3school.com.cn JavaScript学习笔记01[基础--简介.基础语法.运算符.特殊语法.流程控制语句][day01] JavaS ...
最新文章
- Java项目:诚途旅游系统(java+JSP+Spring+SSM+Mysql)
- 【Django】创建项目及框架介绍,学习笔记(一)
- i27岁转行java,JavaTM I/O 性能分析[转]
- 【转】Impala导出查询结果到文件
- 最新阿里内推Java后端面试题
- MySQL删库数据延迟恢复策略
- 《当程序员的那些狗日日子》(三十四)人事变动
- APP打开直接显示图片,去掉中间的白屏时间
- PCM设备的作用,为什么要选用PCM设备?
- hadoopsdk使用_hadoop部署使用问题及解决
- php绘制频谱图,一步一步教你实现iOS音频频谱动画(二)
- mysql clickhouse_通过mysql操作clickhouse
- Loadrunner2021安装教程
- FS4054单节锂电池充电管理芯片,IC电路图
- JAVA之父----詹姆斯.高斯林
- 一张图了解致远A6人事管理
- Snapchat面试题:移除K位
- wi7计算机桌面删除,win7系统删除桌面右键多余选项
- CSS笔试题: 实现表格首行首列固定和自适应窗口
- STM32初学——OLED调试4-1 5-1/5-2
热门文章
- Navicat mysql 加索引_mysql 索引 (Navicat添加索引)
- 中英文怎么算 字符长度_钢材长度怎么算,只有1%的人才懂!
- 自然语言处理美国政客的社交媒体消息分类
- Tomcat 初始化端点错误--Error initializing endpoint
- 从ICLR 2022看什么是好的图神经网络?
- BERT在文档级排序中的应用
- 最新综述:推荐系统的Bias问题和Debias方法
- CVPR 2020 Oral | 无域标签下高清场景时移变换
- PW Live 直播 | 清华大学王晓智:事件抽取的进展与挑战
- EMNLP2018论文解读 | 三种提升多语言翻译模型的高效策略