05浏览器-02-操作DOM
1、DOM操作梗概
// 通过querySelector获取ID为q1的节点
var q1 = document.querySelector('#q1');
// 通过querySelectorAll获取q1节点内的符合条件的所有节点
var ps = q1.querySelectorAll('div.highlighted > p');
- // 通过querySelector获取ID为q1的节点
- var q1 = document.querySelector('#q1');
- // 通过querySelectorAll获取q1节点内的符合条件的所有节点
- var ps = q1.querySelectorAll('div.highlighted > p');
2、更新DOM
// 获取<p id="p-id">...</p>
var p = document.getElementById('p-id');
// 设置文本为abc:
p.innerHTML = 'ABC'; // <p id="p-id">ABC</p>
// 设置HTML:
p.innerHTML = 'ABC <span style="color:red">RED</span> XYZ';
// <p>...</p>的内部结构已修改
- // 获取<p id="p-id">...</p>
- var p = document.getElementById('p-id');
- // 设置文本为abc:
- p.innerHTML = 'ABC'; // <p id="p-id">ABC</p>
- // 设置HTML:
- p.innerHTML = 'ABC <span style="color:red">RED</span> XYZ';
- // <p>...</p>的内部结构已修改
// 获取<p id="p-id">...</p>
var p = document.getElementById('p-id');
// 设置文本:
p.innerText = '<script>alert("Hi")</script>';
// HTML被自动编码,无法设置一个<script>节点:
// <p id="p-id"><script>alert("Hi")</script></p>
- // 获取<p id="p-id">...</p>
- var p = document.getElementById('p-id');
- // 设置文本:
- p.innerText = '<script>alert("Hi")</script>';
- // HTML被自动编码,无法设置一个<script>节点:
- // <p id="p-id"><script>alert("Hi")</script></p>
3、插入DOM
3.1 插入父节点的最后一个子节点 appendChild
<!-- HTML结构 -->
<p id="js">JavaScript</p>
<div id="list">
<p id="java">Java</p>
<p id="python">Python</p>
<p id="scheme">Scheme</p>
</div>
//js操作
var js = document.getElementById('js'),
var list = document.getElementById('list');
list.appendChild(js);
<!-- 新的HTML结构 -->
<div id="list">
<p id="java">Java</p>
<p id="python">Python</p>
<p id="scheme">Scheme</p>
<p id="js">JavaScript</p>
</div>
- <!-- HTML结构 -->
- <p id="js">JavaScript</p>
- <div id="list">
- <p id="java">Java</p>
- <p id="python">Python</p>
- <p id="scheme">Scheme</p>
- </div>
- //js操作
- var js = document.getElementById('js'),
- var list = document.getElementById('list');
- list.appendChild(js);
- <!-- 新的HTML结构 -->
- <div id="list">
- <p id="java">Java</p>
- <p id="python">Python</p>
- <p id="scheme">Scheme</p>
- <p id="js">JavaScript</p>
- </div>
var list = document.getElementById('list'),
var haskell = document.createElement('p');
haskell.id = 'haskell';
haskell.innerText = 'Haskell';
list.appendChild(haskell);
<!-- HTML结构 -->
<div id="list">
<p id="java">Java</p>
<p id="python">Python</p>
<p id="scheme">Scheme</p>
<p id="haskell">Haskell</p>
</div>
- var list = document.getElementById('list'),
- var haskell = document.createElement('p');
- haskell.id = 'haskell';
- haskell.innerText = 'Haskell';
- list.appendChild(haskell);
- <!-- HTML结构 -->
- <div id="list">
- <p id="java">Java</p>
- <p id="python">Python</p>
- <p id="scheme">Scheme</p>
- <p id="haskell">Haskell</p>
- </div>
3.2 插入指定位置 insertBefore
<!-- HTML结构 -->
<div id="list">
<p id="java">Java</p>
<p id="python">Python</p>
<p id="scheme">Scheme</p>
</div>
//js操作
var list = document.getElementById('list'),
var ref = document.getElementById('python'),
var haskell = document.createElement('p');
haskell.id = 'haskell';
haskell.innerText = 'Haskell';
list.insertBefore(haskell, ref);
<!-- 新的HTML结构 -->
<div id="list">
<p id="java">Java</p>
<p id="haskell">Haskell</p>
<p id="python">Python</p>
<p id="scheme">Scheme</p>
</div>
- <!-- HTML结构 -->
- <div id="list">
- <p id="java">Java</p>
- <p id="python">Python</p>
- <p id="scheme">Scheme</p>
- </div>
- //js操作
- var list = document.getElementById('list'),
- var ref = document.getElementById('python'),
- var haskell = document.createElement('p');
- haskell.id = 'haskell';
- haskell.innerText = 'Haskell';
- list.insertBefore(haskell, ref);
- <!-- 新的HTML结构 -->
- <div id="list">
- <p id="java">Java</p>
- <p id="haskell">Haskell</p>
- <p id="python">Python</p>
- <p id="scheme">Scheme</p>
- </div>
var i, c,
var list = document.getElementById('list');
for (i = 0; i < list.children.length; i++) {
c = list.children[i]; // 拿到第i个子节点
}
- var i, c,
- var list = document.getElementById('list');
- for (i = 0; i < list.children.length; i++) {
- c = list.children[i]; // 拿到第i个子节点
- }
4、删除DOM
// 拿到待删除节点:
var self = document.getElementById('to-be-removed');
// 拿到父节点:
var parent = self.parentElement;
// 删除:
var removed = parent.removeChild(self);
removed === self; // true
- // 拿到待删除节点:
- var self = document.getElementById('to-be-removed');
- // 拿到父节点:
- var parent = self.parentElement;
- // 删除:
- var removed = parent.removeChild(self);
- removed === self; // true
05浏览器-02-操作DOM的更多相关文章
- JavaScript学习05(操作DOM)
操作DOM DOM(文档对象模型) 当网页被加载时,浏览器会创建页面的文档对象模型(Document Object Model). HTML DOM 模型被结构化为对象树: 通过这个对象模型,Java ...
- 详解Google Chrome浏览器(操作篇)(下)
开篇概述 由于最近忙于公司产品的架构与研发,已经三个多月没有写博客了,收到有些朋友的来信,问为什么不及时更新博客内容呢,他们说他们正期待着某些内容.对此,非常抱歉,那么我在此也给各位朋友一些承诺,从即 ...
- 【ASP.NET MVC系列】浅谈Google Chrome浏览器(操作篇)(下)
ASP.NET MVC系列文章 [01]浅谈Google Chrome浏览器(理论篇) [02]浅谈Google Chrome浏览器(操作篇)(上) [03]浅谈Google Chrome浏览器(操作 ...
- Javascript操作DOM常用API总结
基本概念 在讲解操作DOM的api之前,首先我们来复习一下一些基本概念,这些概念是掌握api的关键,必须理解它们. Node类型 DOM1级定义了一个Node接口,该接口由DOM中所有节点类型实现.这 ...
- mui项目中如何使用原生JavaScript代替jquery来操作dom 转自【B5教程网】:http://www.bcty365.com/content-146-3661-1.html
最近在用mui写页面,当然了在移动App里引入jq或zepto这些框架,肯定是极不理性的.原生JS挺简单,为何需要jq?jq的成功当时是因为ie6.7.8.9.10.chrome.ff这些浏览器不兼容 ...
- 三、jquery操作DOM
DOM(Document Object Model, 文档对象模型)为文档提供了一种结构化的表示方法,通过该方法可以改变文档的内容和展示形式.在实际运用中,DOM更像是桥梁,通过它可以实现跨平台.跨语 ...
- jQuery操作Dom、jQuery事件机制、jQuery补充部分
jQuery操作Dom: 修改属性: //使用attr()方法 //attr(name, value) //name:要修改的属性的属性名 //value:对应的值 //attr方法,如果当前标签有要 ...
- 浏览器兼容性小记-DOM篇(二)
1.DOM中的所有节点都继承自Node类型,IE9之前将DOM节点作为COM对象来实现:每个DOM节点都有一个nodeType属性来表明节点类型,总共有12个类型: Node.ELEMENT_NODE ...
- 【面试必备】javascript操作DOM元素
前言 时间过的真快,不知不觉就到年底了.问问自己,这一年你对自己的工作满意吗? 评价标准是什么呢?当然是马云的那两条准则了:钱给到了吗?干的爽吗?如果答案都是no,那么,你准备好跳槽了吗? 为了应对年 ...
随机推荐
- Ubuntu Docker 简单安装 GitLab
相关博文: Ubuntu 简单安装 Docker Ubuntu 简单安装和配置 GitLab 服务器版本 Ubuntu 16.04 LTS. 1. 安装和配置 安装命令: sudo docker ru ...
- Struts2学习笔记(九)——数据校验
Struts2的数据校验属于服务器端校验,Struts2 支持校验方式 : 手动校验(代码校验) :在服务器端通过编写java代码,完成数据校验 自动校验(配置校验) :XML配置校验(主流) 和 注 ...
- 带你走进SAP项目实施过程——前言(0)
欢迎关注博主的微信公众号,每天提供原创的SAP技术和项目管理新资讯! 一直很想写一些关于SAP项目管理以及实施过程的系列文章,讲述企业SAP项目从立项开始到启动,再到实施过程,直到最后的上线及总结.我 ...
- TIKV副本一致性检查机制分析
背景 TIKV使用raft协议来实现副本同步,任何时刻写入一个KEY-VAL键值对,都会基于RAFT协议复制到不同机器的三个副本上,raft协议本身能保证副本同步的强一致性,但是任何系统都可能存在BU ...
- 如何删除当前正在使用的SQLLite文件?
从网上搜索一大堆,套路几乎相同,但自己就是不行,怎么也不行,为什么不行呢?不行的话别人肯定不来坑博友了呀.然后放了一会,去拿下午茶回来,再次来看,恍然大悟,What?这么简单. 一开始代码如下: he ...
- web本地存储
Web本地存储 通过本地存储(Local Storage),web 应用程序能够在用户浏览器中对数据进行本地的存储. 在 HTML5 之前,应用程序数据只能存储在 cookie 中,包括每个服务器请求 ...
- mysql查看表结构2种方式对比
1.desc t_bookType; 2.show create table t_bookType; 相信大部分人还是喜欢第一种查看表结构方式.
- C# 爬虫 抓取小说
心血来潮,想研究下爬虫,爬点小说. 通过百度选择了个小说网站,随便找了一本小书http://www.23us.so/files/article/html/13/13655/index.html. 1. ...
- if处理多分支结构
实例1 import java.util.Scanner; /** * Created by liwenj on 2017/7/17. */ public class test7 { public s ...
- python 小技巧 防止SSL报错信息
代码里面 只需要添加如下2行: import ssl ssl._create_default_https_context = ssl._create_unverified_context