首页 > 其他分享 >JS DOM 对象的节点操作

JS DOM 对象的节点操作

时间:2024-08-15 23:53:25浏览次数:18  
标签:blue console log DOM parentNode JS document 节点

目录

一、什么是加载时间onload

二、各种节点的获取方法

1、元素节点的获取

(1)通过标签名获取:

       document.getElementsByTagName('标签名')

(2)通过id获取

         document.getElementById('id的名称')

2、文本节点的获取

举个栗子

3、兄弟节点

(1)nextSibling:获得下一个兄弟节点

(2)previousSibling:获得上一个兄弟节点

(3)childNodes:父节点获得内部全部的子节点信息

4、父节点

三、对节点进行操作

1、属性值操作

(1)获取属性值

(2)设置属性值

2、节点创建和追加

(1)节点创建

(2)节点追加

3、节点删除

四、点击事件

写触发事件有两种方法:

(1)在标签内写onclick事件

(2)在JS写 onlicke=function(){} 函数


一、什么是加载时间onload

js代码执行时候,需要html&css的支持,就让html先执行(先进入内存),js代码后执行。onload在页面加载完之后执行,写法如下(js代码写在函数内部):

window.onload = function() {

}

通俗来说,就是不管Javascript代码被写在<body>的前面还是里面都是先执行别的代码,最后才来执行onload里面的代码。

dom操作就是用JS实现对html标签的增删改查。

二、各种节点的获取方法

1、元素节点的获取

(1)通过标签名获取:

       document.getElementsByTagName('标签名')

通过这种方法得到的是一个数组,可以通过下标(从0开始)来拿到自己想要的节点。

var inputs = document.getElementsByTagName('input');
console.log(inputs);
console.log(inputs[1]);

(2)通过id获取

         document.getElementById('id的名称')

        因为id是唯一的所以通过这种方法获取的节点也是唯一的。

var input = document.getElementById('username');
console.log(input);

2、文本节点的获取

需要借助外部的元素节点再获得其内部的文本节点.

举个栗子

有如下内容:<div>hello</div>

则要获得文本节点需要借助div元素节点再获得其内部的文本节点,具体写法如下:

var dvnode = document.getElementsByTagName(‘div’)[0];
dvnode.firstChild; 

//(或调用lastChild),即获得div节点的第一个孩子节点(因为这里只有一个孩子所以也可以调用lastChild)。

firstChild.wholeText (获取这个文本节点的字符串形式)

3、兄弟节点

续上面,父节点通过firstChild / lastChild,获得第一个/最后一个子节点 后再找到孩子节点的兄弟节点,其中Sibling 是 ”兄弟姐妹“ 的意思,具体有如下几个方法:

(1)nextSibling:获得下一个兄弟节点

(2)previousSibling:获得上一个兄弟节点

(3)childNodes:父节点获得内部全部的子节点信息

<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script type="text/javascript">
			window.onload = function() {
				var ull = document.getElementsByTagName('ul')[0];
				console.log(ull.childNodes);  //输出父节点的全部孩子节点
				console.log(ull.childNodes.length); //全部孩子节点的个数
				console.log(ull.firstChild); //输出第一个孩子节点
				console.log(ull.firstChild.nextSibling);  //输出第一个孩子节点的下一个兄弟节点
				console.log(ull.lastChild); //输出最后一个孩子节点
				console.log(ull.lastChild.previousSibling); //输出最后一个孩子节点的前一个兄弟节点
			}
		</script>
	</head>
	<body>
		<ul>
			<li>red</li>
			<li>blue</li>
			<li>green</li>
		</ul>
	</body>
</html>

4、父节点

获取父节点:节点.parentNode

获取当前结点的父节点就调用一次,获取当前结点的父节点的父节点就调用两次,依次类推:

<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		
	</head>
	<body>
		<ul>
			<li>red</li>
			<li>blue</li>
			<li>green</li>
		</ul>
		
		<script type="text/javascript">
			window.onload = function() {
				var blue = document.getElementsByTagName("li")[1];
				console.log(blue); //li
				console.log(blue.parentNode); //ul
				console.log(blue.parentNode.parentNode); //body
				console.log(blue.parentNode.parentNode.parentNode); //html
				console.log(blue.parentNode.parentNode.parentNode.parentNode); //document
				console.log(blue.parentNode.parentNode.parentNode.parentNode.parentNode); //null
				//console.log(blue.parentNode.parentNode.parentNode.parentNode.parentNode.parentNode); //再写这一行就报错,因为不能是null.parentNode

			}
			
		</script>
	</body>
</html>

三、对节点进行操作

1、属性值操作

(1)获取属性值

itnode.属性名称; //只能操作规定好的属性

itnode.getAttribute(属性名称); //规定的 和 自定义的属性都可以获取

(2)设置属性值

itnode.属性名称 = 值; //只能操作w3c规定的属性 ,不能操作自定义的属性

itnode.setAttribute(名称,值); //规定的 和 自定义的都可以设置

//获取操作
console.log(baidu.addr);// undefined,这里addr是我自定义的属性,采用这种方法不能获取
console.log(baidu.target);//规定的属性采用这种方法可以获取
    //下面这种方法不管是自定义的还是规定的属性都能获取
console.log(baidu.getAttribute('addr'));
console.log(baidu.getAttribute('target'));

//设置属性,同样只有.setAttribute才能设置自定义的属性
baidu.addr = 'tianjin'; 
baidu.className = 'orange'; //这里的clas属性特殊,必须要写成.className而不能是.class
				
baidu.setAttribute('addr', 'shanghai');
baidu.setAttribute('class', 'orange');

2、节点创建和追加

(1)节点创建

  • 元素节点:document.createElement(tag标签名称);
  • 文本节点:document.createTextNode(文本内容);
  • 属性设置:node.setAttribute(属性名称,属性的值);

(2)节点追加

  • 父节点.appendChild(子节点);
  • 父节点.insertBefore(newnode,oldnode); //newnode放到oldnode的前边
  • 父节点.replaceChild(newnode,oldnode); //newnode替换掉oldnode节点
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
	</head>
	<body>
		<!-- 
		<ul>
			<li mean='热情'>red</li>
			<li mean='冷静'>blue</li>
			<li mean='生机'>green</li>
		</ul> 
		--> <!--用下面的代码动态创建这个列表-->
		
		<script type="text/javascript">
			window.onload = function () {
				var colors = ['red', 'blue', 'green'];
				var means = ['热情', '冷静', '生机'];
				var ul = document.createElement("ul");
				for (var i = 0; i < colors.length; i++) {
					var li = document.createElement("li");
					li.setAttribute('mean', means[i]);
					var txt = document.createTextNode(colors[i]);
					li.appendChild(txt);
					ul.appendChild(li);
				}
				document.body.appendChild(ul);
			}
		</script>
	</body>
</html>

3、节点删除

父节点.removeChild(子节点);

//移除blue
var blue = document.getElementsByTagName('li')[1];
blue.parentNode.removeChild(blue);

四、点击事件

通过鼠标、键盘对页面所做的动作就是事件。事件一旦发生需要有事件处理,该处理称为“事件驱动”,事件驱动通常由函数担任,常见事件有:

  • onclick  //点击事件,点击时触发
  • onmouseover //鼠标移到指定元素上就触发
  • onmouseout //鼠标从指定元素上移走时触发
  • onkeyup  //当用户释放键盘上的一个键时触发
  • onkeydown //当用户按下键盘上的一个键时触发
  • onblur //当元素失去焦点时触发
  • onfocus //当元素获得焦点时触发
  • onsubmit  //当表单被提交时触发

写触发事件有两种方法:

(1)在标签内写onclick事件
<input id="btnId" type="button" value="Press Me" onclick="alert('thanks');">
(2)在JS写 onlicke=function(){} 函数
var btn = document.getElementById('btnId');
btn.onclick = function () {
alert('thanks');
}

完结!!!!睡觉

标签:blue,console,log,DOM,parentNode,JS,document,节点
From: https://blog.csdn.net/weixin_72280926/article/details/141233595

相关文章

  • 437.蓝色简单的多乐士油漆公司网站 大学生期末大作业 Web前端网页制作 html+css+js
    目录一、网页概述二、网页文件 三、网页效果四、代码展示1.html2.CSS3.JS五、总结1.简洁实用2.使用方便3.整体性好4.形象突出5.交互式强六、更多推荐欢迎光临仙女的网页世界!这里有各行各业的Web前端网页制作的案例,样式齐全新颖,并持续更新!感谢CSDN,提供了这......
  • js 字符操作 padStart padEnd 使用教程
    padStart和padEnd是JavaScript中字符串方法,用于在字符串的开头或结尾添加填充字符,直到达到指定的长度。padStart(targetLength,padString)targetLength:目标字符串长度。padString:用于填充的字符串。用法:conststr="hello";//在字符串开头添加空格,直到长度为......
  • js 字符操作startswidth 方法使用
    startswidth用于检查字符串是否以指定的子字符串开头。startsWith(searchString,position)searchString:要搜索的子字符串。position:可选参数,指定搜索开始的位置(默认值为0)。用法:conststr="helloworld";//检查字符串是否以"hello"开头conststartsWithHello......
  • js无法操作或者获取哪些真机相关信息
    在JavaScript中,特别是在Web应用程序中,出于安全和隐私的考虑,有一些真机(设备)相关信息是无法被操作或获取的。以下是一些常见的限制:设备唯一标识符:如IMEI、MAC地址等,这些信息通常无法通过JavaScript获取。系统文件:JavaScript无法访问设备的文件系统。硬件信息:如CPU型号、GPU......
  • 分割模型的数据集由json转为txt
    点击查看代码#-*-coding:utf-8-*-importjsonimportosimportargparsefromtqdmimporttqdmimportglobimportcv2importnumpyasnpdefconvert_label_json(json_dir,save_dir,classes):json_paths=os.listdir(json_dir)classes=classes.spli......
  • P1001 A+B Problem(整活-dijstra堆优化)
    OK啊,这就是普通的\(a+b\)嘛这是一道十分淼的题目,乍一看,这不就是dijstra堆优化的模板题吗?首先,建立三个节点,两条线行,OK开始Code#include<bits/stdc++.h>usingnamespacestd;constlonglongN=99999,M=999999;typedefpair<longlong,longlong>PII;priority_......
  • JSONUtil、JsonArray应用 (全网最全面的解析方式汇总) - 调用第三方接口后,获取的结果
    背景:近期开发的内容涉及到了我们平台对其他平台提供接口的调用,然后也涉及到接口提供方的验签等操作;还有我们的加签操作等。今天记录一下调用三方接口后返回的接口如何解析;怎么拿到自己想要的东西。其实调用三方接口分为几步1、采用哪种方式调用三方接口,这种依赖于第三方......
  • JS 数组的用法
    一、常用的测试写法//array的写法varmyArray=["Apple","Orange","Banana"];//一、正常循环写法如下:varfruitFinal3=""for(vari=0;i<myArray.length;i++){fruitFinal3+=myArray[i]+""......
  • docker 配置daemon.json镜像源地址
    docker镜像拉取失败网络异常?errorpullingimageconfiguration:downloadfailedafterattempts=6:dialtcp108.160.172.208:443:connect:connectionrefused原因:docker镜像源访问失败,或网络严重延迟,或没有设置镜像源文件daemon.jsondocker配置国内镜像源前言1、docke......
  • 自定义JSON名
    lSer:=TMVCJsonDataObjectsSerializer.Create;trylSer.DataSetToJsonArray(MasterDBHelper.Query,lJObj.a['m'],TMVCNameCase.ncLowerCase,[],procedure(constaField:TField;constaJsonObject:TJSONObject......