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同理)

JavaScript选择器和节点操作的更多相关文章
- 前端JavaScript之DOM节点操作
1.HTML DOM是啥 Document Object Model:定义了访问和操作HTML文档的标准方法,把HTML文档呈现为带有元素,属性和文本的树状结构 2.解析过程 HTML加载完毕,渲染引 ...
- JavaScript原生的节点操作
前言:原生是Javascript的基础,还是需要多多重视,时间长都忘记了,现在整理一下. 获取子节点 children 不是标准的dom属性,但是几乎被所有浏览器支持.不包含文本节点. 注意:在IE中 ...
- JavaScript之DOM节点操作
a.appendChild(b) 追加标签 a是b的父级,将b追加到a中 追加标签 a.insertBefore(b,c); a是b和c的父级,在c前面插入b 删除标签 a.removeCli ...
- javascript之表格节点操作
<html> <div class='add'> 名字: <input type="" name=""&g ...
- JS节点操作(JS原生+JQuery)
JavaScript与JQuery节点操作 节点关系与类型 任何HTML元素,都有nodeType属性.值有1~12,常用的有: 1.元素节点 2.文本节点 8.注释节点 9.document节点 ...
- JavaScript 节点操作Dom属性和方法(转)
JavaScript 节点操作Dom属性和方法 一些常用的dom属性和方法,列出来作为手册用. 属性: 1.Attributes 存储节点的属性列表(只读) 2.childNodes 存储 ...
- 使用HTML5的JavaScript选择器操作页面中的元素
<!doctype html><html lang="en"> <head> <meta charset="UTF-8& ...
- JavaScript -- 节点操作, 事件触发, 表单伸缩
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- JavaScript之DOM操作,事件操作,节点操作
1,DOM操作 1.1 概念 所谓DOM,全称Document Object Model 文档对象模型,DOM是W3C(World Wide Web Consortuum )标准,同时也定义了访问诸 ...
随机推荐
- H3C S5500V2交换机误格式化恢复
一.格式化后,bin文件及视图全部被删除需要联系H3C客服报交换机后面的序列号,然后根据工单中给你的账号密码去H3C官网下载对应的软件包. 二.下载3CDaemon使用TFTP方式将解压出来的.ipe ...
- logger日志接口SLF4J
SLF4J只是一个接口,可以实现程序的解藕.SLF4J可以与log4j.logback.jdk等日志系统结合,以及在这些日志系统之间切换. 使用maven导入各个日志系统的jar包.需要注意的是要写相 ...
- ftp服务器搭建(二)
1.已经安装好了vsftpd 进入到根目录下的/etc目录 ls查看一下 2.拷贝一下上面的两个配置文件 我拷贝到了我新建的目录中了 3.查看现在的网络连接方式——我的是-net方式 当然其他方式也 ...
- UVA 11651
题目链接:https://cn.vjudge.net/problem/UVA-11651 解题思路: 思路来源于网络. DP + 矩阵快速幂. 设 dp[i][j] 为满足 score 为 i 且最后 ...
- 技术大佬:我去,你竟然还不会用 this 关键字
上一篇文章写的是 Spring Boot 的入门,结果有读者留言说,Java 都还没搞完,搞什么 Spring Boot,唬得我一愣一愣的.那这篇就继续来搞 Java,推出广受好评的我去系列第四集:你 ...
- GRpc添加客户端的四种方式
随着微服务的发展,相信越来越多的.net人员也开始接触GRpc这门技术,大家生成GRpc客户端的方式也各不相同,今天给大家介绍一下依据Proto文件生成Rpc客户端的四种方式 前提:需要安装4个Nug ...
- Springboot整合MybatisPlus(超详细)完整教程~
新建springboot项目 开发工具:idea2019.2,maven3 pom.xml <dependency> <groupId>org.springframework. ...
- 使用PInvoke互操作,让C#和C++愉快的交互优势互补
一:背景 1. 讲故事 如果你常翻看FCL的源码,你会发现这里面有不少方法借助了C/C++的力量让C#更快更强悍,如下所示: [DllImport("QCall", CharSet ...
- 技术大佬:我去,这个容易被忽略的小程序Image图片属性,竟然这么屌!
前段时间在做“高清壁纸推荐”小程序优化的时候,发现一个很实用的图片属性——能够实现最大化压缩图片大小.且图片质量最小的损失,在此之前一直没有注意.今天跟大家分享一下这个属性的用法,主要是让大家能够,意 ...
- [256个管理学理论]001.蝴蝶效应(Butterfly Effect)
蝴蝶效应(Butterfly Effect) 来自于大洋彼岸的让你看不懂的解释: 蝴蝶效应是指在一个动力系统中,初始条件下微小的变化能带动整个系统的长期的巨大的连锁反应,是一种混沌的现象.“蝴蝶效应” ...