JS系列:js节点
节点(node)
在html文档中出现的所有东西都是节点
元素节点(HTML标签)
文本节点(文字内容)
注释节点(注释内容)
文档节点(document)
…
每一种类型的节点都会有一些属性区分自己的特征与特性
nodeType: 节点类型
nodeName:节点名称
nodeValue:节点值
元素节点
nodeType:1
nodeName:”DIV” //大写的标签名
nodeValue:null //节点值
文本节点
nodeType:3
nodeName:‘text’
nodeValue:文本内容
注释节点
nodeType:8
nodeName:‘#comment’
nodeValue:注释内容
文档节点
nodeType:9
nodeName:‘#document’
nodeValue:null
描述节点关系之间的属性
parentNode
获取当前节点唯一的父亲节点
childNodes
获取当前元素的所有子节点
子节点:只获取儿子级别的
所有:含元素节点,文本节点
children
获取当前元素所有的元素子节点
在ie6-8把元素节点也当做元素节点获取到,所有兼容性不好
previousSibling
获取当前节点的上一个哥哥节点(可能是元素或者文本等)
previousElementSibling
获取当前节点的上一个哥哥元素节点(不兼容ie6-8)
nextSibling
获取当前节点的下一个弟弟节点(可能是元素或者文本等)
nextElementSibling
获取当前节点的下一个弟弟元素节点(不兼容ie6-8)
firstChild
获取当前元素第一个子节点(可能是元素或者文本等)
firstElementChild
获取当前元素第一个元素子节点(不兼容ie6-8)
lastChild
获取当前元素最后一个子节点(可能是元素或者文本等)
lastElementChild
获取当前元素最后一个元素子节点(不兼容ie6-8)
需求1:获取当前元素的所有子节点
基于children不兼容ie低版本的浏览器(会把注释节点当做元素节点)
源码如下:
效果如下:

需求2:获取当前元素的上一个哥哥元素节点
previousSibling: 上一个哥哥节点
previousElementSibling : 上一个哥哥元素节点,但不兼容ie6-8
结构如下:

扩展:next下一个弟弟元素节点,preAll获取所以哥哥元素节点,nextAll获取所以弟弟元素节点,siblings获取所有兄弟元素节点,index获取当前元素的索引…
### 节点(node)> 在html文档中出现的所有东西都是节点> - 元素节点(HTML标签)> - 文本节点(文字内容)> - 注释节点(注释内容)> - 文档节点(document)> - ...每一种类型的节点都会有一些属性区分自己的特征与特性- nodeType: 节点类型- nodeName:节点名称- nodeValue:节点值`元素节点`nodeType:1nodeName:"DIV" //大写的标签名nodeValue:null //节点值`文本节点`nodeType:3nodeName:‘text’ nodeValue:文本内容`注释节点`nodeType:8nodeName:‘#comment’nodeValue:注释内容`文档节点`nodeType:9nodeName:‘#document’nodeValue:null ###描述节点关系之间的属性**`parentNode`**> 获取当前节点唯一的父亲节点**`childNodes`**> 获取当前元素的所有子节点> - 子节点:只获取儿子级别的> - 所有:含元素节点,文本节点**`children`**> 获取当前元素所有的元素子节点> - 在ie6-8把元素节点也当做元素节点获取到,所有兼容性不好**`previousSibling`**> 获取当前节点的上一个哥哥节点(可能是元素或者文本等)**`previousElementSibling`**> 获取当前节点的上一个哥哥元素节点(不兼容ie6-8)**`nextSibling`**> 获取当前节点的下一个弟弟节点(可能是元素或者文本等)**`nextElementSibling`**> 获取当前节点的下一个弟弟元素节点(不兼容ie6-8)**`firstChild`**> 获取当前元素第一个子节点(可能是元素或者文本等)**`firstElementChild`**> 获取当前元素第一个元素子节点(不兼容ie6-8)**`lastChild`**> 获取当前元素最后一个子节点(可能是元素或者文本等)**`lastElementChild`**> 获取当前元素最后一个元素子节点(不兼容ie6-8)需求1:获取当前元素的所有子节点> 基于children不兼容ie低版本的浏览器(会把注释节点当做元素节点)```javascript//=> 标准注释/** children:获取当前元素的所有子节点 Gets all child nodes of the current element* @parameter 参数* curEle:current element* @return* [array] all the element nodes* * by team on 2018/04/07 12:36* update lifei */ function children(curEle){ //1.先获取当前元素下所有的子节点 //2.存放新数组result //3.遍历这些节点 //4.筛选出元素NODE-type===-1,把筛选出来的结果单独存储起来即可 var nodeList = curEle.childrenNodes, result = []; for(var i = 0; i < nodeList.length; i++){ var item = nodeList[i]; if(item.nodeType === -1){ result.push(item); } } return result; }```源码如下:```handlebars <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title></head><body> <!-- 前端小白到前端全栈:勿忘初心,方得始终 --> <ul id="course"> <!-- 第一阶段:原生js --> <li>闭包,作用域,THIS,OOP</li> <li>DOM渲染机制和性能优化</li> <li>正则表达式解析处理</li> <li>定时器和js异步编程</li> <li>js中的事件模型</li> <li>JQ实战应用和源码解读</li> <li>JS中的设计模式:单例,发布订阅,构造,原型,Promise...</li> <!-- 第二阶段:项目实战和响应式开发 --> <li>Hybrid混合式响应式布局开发</li> <li>Ajax及跨域请求</li> <li>前后端分离和http基础</li> <!-- 第三阶段:全栈工程化开发 --> <li>NODE基础:能够基于Express/koa等框架编写伪API</li> <li>VUE及全家桶:vue-cli\vue\vue-router\vuex\axios...</li> <li>React及全家桶:react\react-dom\react-router\redux\react-redux\dva\ant...</li> <li>webpack</li> <li>git</li> <!-- 第四阶段:选学 --> <li>微信小程序</li> <li>Canvas高级开发</li> <li>React Native</li> </ul> <script> // var course = document.getElementById function children(curEle) { //1.先获取当前元素下所有的子节点 //2.存放新数组result //3.遍历这些节点 //4.筛选出元素NODE-type===-1,把筛选出来的结果单独存储起来即可 var nodeList = curEle.childNodes, result = []; for (var i = 0; i < nodeList.length; i++) { var item = nodeList[i]; if (item.nodeType === 1) { result.push(item); } } return result; } console.log(children(course)); </script></body></html>```效果如下:需求2:获取当前元素的上一个哥哥元素节点> previousSibling: 上一个哥哥节点> previousElementSibling : 上一个哥哥元素节点,但不兼容ie6-8```handlebars <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title></head><body> <!-- 前端小白到前端全栈:勿忘初心,方得始终 --> <ul id="course"> <!-- 第一阶段:原生js --> <li>闭包,作用域,THIS,OOP</li> <li>DOM渲染机制和性能优化</li> <li>正则表达式解析处理</li> <li>定时器和js异步编程</li> <li>js中的事件模型</li> <li>JQ实战应用和源码解读</li> <li>JS中的设计模式:单例,发布订阅,构造,原型,Promise...</li> <!-- 第二阶段:项目实战和响应式开发 --> <li>Hybrid混合式响应式布局开发</li> <li>Ajax及跨域请求</li> <li>前后端分离和http基础</li> <!-- 第三阶段:全栈工程化开发 --> <li>NODE基础:能够基于Express/koa等框架编写伪API</li> <li>VUE及全家桶:vue-cli\vue\vue-router\vuex\axios...</li> <li>React及全家桶:react\react-dom\react-router\redux\react-redux\dva\ant...</li> <li>webpack</li> <li>git</li> <!-- 第四阶段:选学 --> <li id="itemN">微信小程序</li> <li>Canvas高级开发</li> <li>React Native</li> </ul> <script> /* 标准注释: 需求2:获取当前元素的上一个哥哥元素节点 * Gets the last sibling element node of the current element 获取当前元素的上一个哥哥元素节点 * @parament参数 * curEle: [object] current element * @return * [object] last elder brother element * by team on 2018/04/04 12:44 */ function pre(curEle) { //=>先找当前元素的哥哥的节点,看是否为元素节点,不是的话,基于哥哥找哥哥的哥哥就是上一个哥哥节点,一直找到元素节点或者已经没有哥哥了,说明我就是老大,则结束查找 // * for循环知道次数,while不知道循环次数,使用while循环 var pre = curEle.previousSibling; while (pre && pre.nodeType !== 1){ /* * pre && pre.nodeType !== 1 其中pre是验证还有没有,这样写代表有,没有pre是null * pre.nodeType是验证是否为元素 */ pre = pre.previousSibling; } return pre; } console.log(pre(itemN)); // 需求1:获取当前元素的所有子节点 /* * children:获取当前元素的所有子节点 Gets all child nodes of the current element * @parameter 参数 * curEle:current element * @return * [array] all the element nodes * * by team on 2018/04/07 12:36 * update lifei */ // function children(curEle) { // //1.先获取当前元素下所有的子节点 // //2.存放新数组result // //3.遍历这些节点 // //4.筛选出元素NODE-type===-1,把筛选出来的结果单独存储起来即可 // var nodeList = curEle.childNodes, // result = []; // for (var i = 0; i < nodeList.length; i++) { // var item = nodeList[i]; // if (item.nodeType === 1) { // result.push(item); // } // } // return result; // } // console.log(children(course)); </script></body></html> ```结构如下:扩展:next下一个弟弟元素节点,preAll获取所以哥哥元素节点,nextAll获取所以弟弟元素节点,siblings获取所有兄弟元素节点,index获取当前元素的索引...
JS系列:js节点的更多相关文章
- Node.js系列-express(上)
前言 Node.js系列的第一篇:http,大概描述了通过使用node.js内置的api创建一个服务并监听request实现简单的增删改查.现在,我们就通过通读express官网及使用express框 ...
- Vue.js系列之三模板语法
Vue.js 使用了基于 HTML 的模板语法,允许开发者声明式地将 DOM 绑定至底层 Vue 实例的数据.所有 Vue.js 的模板都是合法的 HTML ,所以能被遵循规范的浏览器和 HTML 解 ...
- Ember.js系列文章
JS前端框架之Ember.js系列文章 本文为文章索引,主要是罗列Ember.js的相关文章便于阅读. 相关演示代码:github for free. 基础篇 1. EmberJs之What|Why| ...
- 【D3.V3.js系列教程】--(十四)有路径的文字
[D3.V3.js系列教程]--(十四)有路径的文字 1. 在 svg 中插入一個 text // 在 body 中插入一個 svg var svg = d3.select('body').appen ...
- 【D3.V3.js系列教程】--(十五)SVG基本图形绘制
[D3.V3.js系列教程]--(十五)SVG基本图形绘制 1.path <!DOCTYPE html> <html> <head> <meta charse ...
- 【D3.V3.js系列教程】--(十二)坐标尺度
[D3.V3.js系列教程]--(十二)坐标尺度 1.多种类型的缩放尺度 Quantitative Scales Linear Scales Identity Scales Power Scales ...
- node.js系列笔记之node.js初识《一》
node.js系列笔记之node.js初识<一> 一:环境说明 1.1 Linux系统CentOS 5.8 1.2 nodejs v0.10.15 1.3 nodejs源码下载地址 htt ...
- 微信JS图片上传与下载功能--微信JS系列文章(三)
概述 在前面的文章微信JS初始化-- 微信JS系列文章(一)中已经介绍了微信JS初始化的相关工作,接下来本文继续就微信JS的图片上传功能进行描述,供大家参考. 图片上传 $(function(){ v ...
- 微信JS分享功能--微信JS系列文章(二)
概述 在上一篇文章微信JS初始化-- 微信JS系列文章(一)中已经介绍了微信JS初始化的相关工作,接下来本文继续就微信JS的分享功能进行描述,供大家参考. 代码 $(document).ready(f ...
- js系列教程2-对象、构造函数、对象属性全解
全栈工程师开发手册 (作者:栾鹏) 快捷链接: js系列教程1-数组操作全解 js系列教程2-对象和属性全解 js系列教程3-字符串和正则全解 js系列教程4-函数与参数全解 js系列教程5-容器和算 ...
随机推荐
- [springboot 开发单体web shop] 7. 多种形式提供商品列表
上文回顾 上节 我们实现了仿jd的轮播广告以及商品分类的功能,并且讲解了不同的注入方式,本节我们将继续实现我们的电商主业务,商品信息的展示. 需求分析 首先,在我们开始本节编码之前,我们先来分析一下都 ...
- (线段树)A Corrupt Mayor's Performance Art
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5023 题意: 区间更新, 区间询问: 题解: 区间更新, 区间询问, 一共30种颜色, 可用int 来 ...
- Vue项目使用CSS变量实现主题化
主题化管理经常能在网站上看到,一般的思路都是将主题相关的CSS样式独立出来,在用户选择主题的时候加载相应的CSS样式文件.现在大部分浏览器都能很好的兼容CSS变量,主题化样式更容易管理了.最近,使用C ...
- 玩转网络(一)用TTL(Time To Live)排查网络问题
先大概介绍一下TTL(Time To Live)吧! TTL翻译过来就是网络生存时间,说的是一个网络数据包,它在网络设备中转发的跳数(网络设备这里一般指的是路由器),默认值为64,也有很多设置为了12 ...
- PostGIS mysql_fdw使用(Linux)
##前文讲了mysql_fdw的安装,此文主要讲mysql_fdw的配置以及使用 ##附上前文链接:https://www.cnblogs.com/giser-s/p/11208803.html 背景 ...
- python--数字灯管
import turtle import time def drawLine(draw): #绘制单段数码管 turtle.pendown() if draw else turtle.penup() ...
- NTP服务搭建详解一条龙
说在前面:ntp和ntpdate区别 ①两个服务都是centos自带的(centos7中不自带ntp).ntp的安装包名是ntp,ntpdate的安装包是ntpdate.他们并非由一个安装包提供. ② ...
- supervisor 安装配置详解
一.安装 源码安装 先下载最新的supervisor安装包:https://pypi.python.org/pypi/supervisor , 如: (python3命令为 pip install g ...
- 转载 C#中DataTable中的Compute方法使用收集
原文: C#中DataTable中的Compute方法使用收集 Compute函数的参数就两个:Expression,和Filter. Expresstion是计算表达式,关于Expression的详 ...
- linux+docker+nginx如何配置环境并配置域名访问
一.环境准备 1)下载php环境包,下载地址为:https://www.php.net/downloads.php 2)安装docker,这个主要的作用就是用来安装mysql.你也可以不需要安装这个东 ...