感谢:链接(视频讲解很清晰)
下文中讲解用到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同理)
