第十章:DOM
<div class="wrap">
<ul id="ul">
<li>01</li>
<li>02</li>
<li>03</li>
<li>04</li>
</ul>
</div>
<script>
var ul = document.getElementById('ul');
var lis=document.querySelectorAll('li');
console.log(ul.nodeType);//1:元素节点 2:属性节点 3文本节点
console.log(ul.nodeName);//元素标签名
console.log(ul.nodeValue);//始终为null
console.log(lis);
console.log(Object.getOwnPropertyDescriptor(window,'lis'));
console.log(lis.item(0));
console.log(lis.constructor); //查看构造函数
console.log(Array.from(lis))//转化为数组 </script>
<div class="wrap">
<ul id="ul">
<li>01</li>
<li>02</li>
<li>03</li>
<li>04</li>
</ul>
</div>
<script>
var ul=document.querySelector('ul');
var li=document.querySelector('li');
var lis=document.querySelectorAll('li'); /*节点之间关系*/
console.log(ul.firstChild);//子集节点
console.log(ul.firstElementChild);//子集第一个元素节点
console.log(ul.lastElementChild);//子集最后一个元素节点 console.log(li.parentNode);//直接父元素
console.log('下一个兄弟元素节点',li.nextElementSibling);//下一个兄弟元素节点
console.log('上一个兄弟元素节点',li.previousElementSibling);//上一个兄弟元素节点
console.log(ul.childNodes);//ie9+ ie8会有文本节点 /*\
* 父.appendChild(子) 父级元素内部最下面添加子元素
* 父.insertBefore(要插入的元素,子元素)
* 父.replaceChild(新元素,被替换掉的子元素);//
*
* */
var myli=document.createElement('li');
var p=document.createElement('p')
p.innerHTML='dasda';
myli.setAttribute('name','li');
myli.innerText=33; myli1=myli;//如果不赋值 下面两句会操作同一个节点
ul.appendChild(myli);
ul.insertBefore(myli,li);
ul.replaceChild(p,li);// /*节点复制*/
var clone=ul.cloneNode(); //克隆其自身不包含子元素
var clone1=ul.cloneNode(true);//深复制 会克隆他的子元素
console.log(clone);
console.log(clone1);
<div class="wrap">
<ul>
<li>01</li>
<li>02</li>
<li>03</li>
<li>04</li>
<li>05</li>
</ul>
</div>
<script>
/*
* js中通过Document类型表示文档
* 在浏览器中document对象是HTMLDocument的一个实例 表示整个页面
* document 是window对象的一个属性
*
*
* */ console.log(document.constructor) //ƒ HTMLDocument() { [native code] } console.log(window.document);
console.log(window.document.nodeName);
console.log(window.document.nodeValue);
console.log(window.document.nodeType);
/*下面两个输出一致指向html*/
console.log(document.childNodes[1]);//
console.log(document.documentElement);
console.log(document.body);
console.log(document.doctype);//各浏览器支持程度不一样
console.log(document.doctype === document.childNodes[0]);//true
console.log(document.title);//文档标题 可赋值
console.log(document.URL);//
console.log(document.domain);//域名
console.log(document.URL === location.href);//true /*查找元素*/
var nodes = document.getElementsByTagName('*');
console.log(nodes)
/*
setAttribute()
getAttribute()
removeAttribute()
* */
var li=document.querySelector('li');
li.setAttribute('name','hxq');
li.setAttribute('www','hxq');
console.log(li.getAttribute('name'));
li.removeAttribute('name')
第十章:DOM的更多相关文章
- 第十章 DOM
10.1节点层次 html元素通过元素节点表示,特性节点通过特性节点表示,文档类型节点通过文档类型节点访问,这些类型都继承一个基类型. 10.1.1 Node类型 JavaScript中的所有节点类型 ...
- JavaScript高级程序设计学习笔记第十章--DOM
1.DOM:文档对象模型,是针对 HTML 和 XML 文档的一个 API(应用程序编程接口). 2.DOM 可以将任何 HTML 或 XML 文档描绘成一个由多层节点构成的结构. 3.文档节点是每个 ...
- JAVASCRIPT高程笔记-------第十章 DOM对象
10.1.1 node类型 --除IE外 所有浏览器都可以访问到这个类型 :JS中所有的节点类型都继承自Node类型 nodeName 与nodeValue 如果是一个元素 那么nodeName中保 ...
- 第十章—DOM(0)—NODE类型
DOM1定义了一个node接口,该接口由DOM的所有节点类型实现. 所有的节点都存在这样或那样的关系.在HTML中,head,body可以看出是html的子元素,html是head,body的父元素, ...
- 第十章—DOM(一)——Document类型
DOCUMENT类型 JS通过document类型表示文档,在文档中document对象是HTMLDocument的一个实例,表示整个HTML页面.document对象是window对象的一个属性,因 ...
- 读书笔记 - js高级程序设计 - 第十章 DOM
文档元素 是文档的最外层元素,在Html页面中,文档元素始终都是<html>元素 在xml中,任何元素都可以是文档元素 Node类型 Node.ELEMENT_NODE 元素 Node ...
- 第十章—DOM(三)——Text类型
文本节点由TEXT类型表示,包含纯文本内容,Text节点具有以下特征: 看看下面的代码: div元素开始和结束标签只要存在内容,就会创建一个文本节点.可以使用以下代码来访问元素的这些文本子节点: 访问 ...
- 第十章—DOM(二)——Element类型
Element类型用于表现HTML和XML,提供了对元素标签名,子节点和特效的访问.Element节点具有以下特征: 要访问元素的标签名,可以使用nodeName属性,也可以使用tagName属性.这 ...
- 第10章DOM笔记
第十章 DOM 一 Node类型 共有12种节点类型,每个节点都有nodeType属性,用于表明节点类型,nodename 表示标签名称 nodeValue始终为null 1.操作节点 a) app ...
- js-JavaScript高级程序设计学习笔记6
第八章 BOM 1.BOM的核心对象是window,他表示浏览器的一个实例.在浏览器中,window对象有双重角色,它既是通过JS访问浏览器窗口的一个接口,又是ES规定的Global对象. 2.定义全 ...
随机推荐
- ROS Learning-016 Arduino-For-ROS-001 搭建 Arduino 和 ROS 之间相连接的开发环境
Arduino For ROS-001 - 搭建 ROS 和 Arduino 相连接的开发环境 我的Ubuntu系统:Ubuntu 14.04.10 TLS 32位 Arduino的版本:Arduin ...
- dpdk中uio技术
总结一下dpdk的uio技术 一:什么是uio技术 UIO(Userspace I/O)是运行在用户空间的I/O技术,Linux系统中一般的驱动设备都是运行在内核空间,而在用户空间用应用程序调用即可, ...
- can通信实验
源码讲解 1.硬件连接 需要两个开发板 2.初始化函数讲解 针对F103的 3.发送函数讲解 4.接收函数讲解 5.main函数讲解
- 关于Java中hashCode方法的实现源码
首先来看一下String中hashCode方法的实现源码. public int hashCode() { int h = hash; if (h == 0 && value.leng ...
- Java50道经典习题-程序40 字符串排序
题目:根据字符串内字符的ASCII码值对字符串数组进行排序.分析:字符串用ASCII码比较大小,规则是:1.比较首字母的ASCII码大小2.若是前面的字母相同,则比较之后的字母的ASCII码值3.若是 ...
- Metasploit 读书笔记-持久控制
Meterpreter的persisitence脚本允许主任meterpreter代理,以确保系统重启之后Meterpreter还能运行。如果是反弹连接方式,可以设置连接攻击机的时间间隔。如果是绑定方 ...
- 自定义Mybatis框架
项目结构: https://files-cdn.cnblogs.com/files/mkl7/ownMybatis.zip 1. 创建maven工程并引入坐标: <?xml versi ...
- [LeetCode] 92. Reverse Linked List II_Medium tag: Linked List
Reverse a linked list from position m to n. Do it in one-pass. Note: 1 ≤ m ≤ n ≤ length of list. Exa ...
- Linux之NFS网络文件系统
NFS(Network File System)即网络文件系统,是FreeBSD支持的文件系统中的一种,它允许网络中的计算机之间通过TCP/IP网络资源共享.在NFS的应用中,本地NFS的客户端应用可 ...
- P5212 SubString LCT+SAM
$ \color{#0066ff}{ 题目描述 }$ 给定一个字符串init,要求支持两个操作 在当前字符串的后面插入一个字符串 询问字符串ss在当前字符串中出现了几次?(作为连续子串) 强制在线. ...