JavaScript选择器和节点操作

感谢:链接(视频讲解很清晰)

下文中讲解用到Chrome中的console调试台,如果不懂最好先看一下:链接

JavaScript选择器

作用:选取html中的标签等内容,最重要的还是为节点的操作(增删查改)做准备。

常用选择器:

1、id选择器(document.getElementById( );) 

例如从下面的网页中找到 id='d0 ' 的标签:

<body>
	<div id="d0" class="div">这是一个div</div>
	<script type="text/javascript">
		var getDiv=document.getElementById('d0');
		console.log('getdiv');
	</script>
</body>

运行截图:(通过上面的函数直接就能把获取到的标签内容存入getDiv中)

2、class选择器(getElementsByClassName();)

实现和上面一样的例子,但由于id在整个html中只有一个但class不同,所以如果存在多个classname满足选择条件会将他们存入一个数组中。

例如:

<body>
	<div id="d0" class="div">这是一个div0</div>
	<div id="d1" class="div">这是一个div1</div>
	<div id="d2" class="div">这是一个div2</div>
	<div id="d3" class="div">这是一个div3</div>
	<script type="text/javascript">
		var getDiv=document.getElementsByClassName('div');
		console.log(getDiv);
	</script>
</body>

运行截图:(把数组展开如下)

也可以给getdiv加下标来获取特定的标签:

3、其它选择器(document.querySelector();document.querySelectorAll();)

注:该选择器兼容性差,但操作简单便于实现。

红框中的内容说明这个选择器的括号中要加的是css选择器,即:如果要选id就用'#', class就用' . ' 。

运行截图:

节点操作:

上面讲解的js选择器就是在给节点操作做准备,因为只有先找到该节点才能操作。

1、查找:

就不需要说了,上面js选择器的作用就是这个。

2、增加:(document.createElement();)

<body>
	<div id="d0" class="div">这是一个div0</div>
	<script type="text/javascript">
		var p=document.createElement('p');
		p.innerHTML="这是一个p标签";
	</script>
</body>

但运行之后div标签没变化,为什么? 

因为这个函数只是先申请一个p ,就算要加上p标签他也不知道往哪加,所以还需要一个函数(*.appendChild(p);) , 其中*代表js选择器选择的要增加的位置

<body>
	<div id="d0" class="div">这是一个div0</div>
	<script type="text/javascript">
		var p=document.createElement('p');
		var getDiv=document.getElementById('d0');
                //若通过class属性获得了位置不唯一,会报错,因为appendChild函数只能给一个标签添加子标签   
		p.innerHTML="这是一个p标签";
		getDiv.appendChild(p);
	</script>
</body>

运行截图:(可以看到div下多了个p标签) 

3、删除:

函数:*1.removeChild(*2);其中*1,*2为父子关系的两个标签

<body>
	<div id="d0" class="div">
		<p id='p0'>这是一个p标签</p>
	</div>
	<script type="text/javascript">
		var getDiv=document.getElementById('d0');
		var getP=document.getElementById('p0');
		getDiv.removeChild(getP);
	</script>
</body>

运行截图:

4、修改(运用最广泛的一种节点操作)

a.与css中的style相关的修改:

<body>
	<div id="d0" class="div">
		<p id='p0'>这是一个p标签</p>
	</div>
	<script type="text/javascript">
		var getDiv=document.getElementById('d0');
		getDiv.style.backgroundColor='red';
                //注意与css中的style:background-color: red;的区别
		getDiv.style.color='purple';
	</script>
</body>

运行截图: 

 

b.修改id或修改classname:

<body>
	<div id="d0" class="div">
		<p id='p0'>这是一个p标签</p>
	</div>
	<script type="text/javascript">
		var getDiv=document.getElementById('d0');
	        getDiv.id='ddd';
	</script>
</body>

修改成功:(classname同理)

原文地址:https://www.cnblogs.com/ldu-xingjiahui/p/12594054.html