DOM基础之“寻找”子节点
今天学习了JS中的DOM的内容,虽然小菜的理解不深,但希望能够记录下来,慢慢一点一点的进步,有更深的理解了,再回来补充。
首先,关于DOM的概念:
1.概念:DOM = document(文档)Object(对象)Model(模型)
文档:就是我们所说的html的页面
对象:指的是html页面中的元素,也成为标签
文档对象模型:则是规定的一系列能够为了让我们用JS更好操作页面元素的标准
2.在DOM下把文档当作树状结构,同时定义了很多方法来操作树中的每一个分支元素(节点)

3.如何寻找子节点
要寻找元素的子节点的方法有很多,但大部分都具有兼容性问题额,以上图的ul、li为例讨论下面的方法
<ul id = "oUl">
<li>111</li>
<li>222</li>
<li>333</li>
<li>444</li>
</ul>
- childNodes 属性 ====> oUl.childNodes
可以用childNodes属性来找到ul下所有的子节点li(是节点列表集合,即能找到所有li),并且只能访问元素的直系子节点(如果li里面还有别的元素是无法访问到的)
注意:childNodes在标准浏览器下:
会包含元素节点+文本节点(空格、回车等),并且允许非法嵌套(如ul里有<p>也会选中); ==》宽容
在非标准的IE浏览器下:
只包含元素节点,并且不允许非法嵌套; =====》不够宽容
对于此类的兼容问题我是这样记得,标准浏览器比较宽容,所以它大方的把文本节点也给你算上了(虽然不一定是好事),并且就连不是自己的孩子,也当作自己的。哈哈
非标准的IE就不够宽容啦,不是我的我不要~
- firstChild 与 firstElementChild 属性 -------》寻找元素的第一个子节点 oUl.firstChild/firstElementChild
两者的区别:firstChild在标准浏览器下:元素节点+文本节点 =====》宽容
在非标准IE下: 元素节点 ====》不宽容
firstElementChild属性只在IE浏览器才拥有
解决兼容问题方法:
var oFirst = oUl.firstElementChild || oUl.firstChild ;
oFirst.style.background = 'red'; //这样无论是IE还是标准下都可以oul下的第一个子元素添加一个红色背景了
那么问题又来了,如果Ul下没有元素呢???? 我还不知道,望告知,或者我一会再去查。
- lastChild 与 lastElementChild 属性 -------》寻找元素的最后一个子节点 oUl.lastChild/lastElementChild
跟第一个的一样,lastChild在标准下宽容(文本+元素);非标准IE下不宽容(元素)
解决兼容:
var oLast = oUl.lastElementChild || oUl.lastChild ;
oLast.style.background = 'red';
-----------推荐使用寻找子节点的方法-------------------------------------
- children 属性 -------》寻找元素的所有子节点列表集合 oUl.children.length ==>得到li的个数
children 在标准浏览器下:元素节点+允许非法嵌套
在非标准IE下:元素节点 +不允许非法嵌套
-----------寻找兄弟节点的方法-------------------------------------
- nextSibling与nextElementSibling 属性 -------》寻找当前元素的下一个兄弟节点 oUl.oFirst.nextSibling/nextElementSibling
- previousSibling与previousElementSibling 属性 -------》寻找当前元素的上一个兄弟节点 oUl.oLast.previousSibling/previousElementSibling
DOM基础之“寻找”子节点的更多相关文章
- DOM的概念及子节点类型
前言 DOM的作用是将网页转为一个javascript对象,从而可以使用javascript对网页进行各种操作(比如增删内容).浏览器会根据DOM模型,将HTML文档解析成一系列的节点,再由这些节点组 ...
- DOM的概念及子节点类型【转】
前言 DOM的作用是将网页转为一个javascript对象,从而可以使用javascript对网页进行各种操作(比如增删内容).浏览器会根据DOM模型,将HTML文档解析成一系列的节点,再由这些节点组 ...
- 遍历DOM树,获取子节点
获取子节点的方法有: 方法 说明 children() 选取子节点,可以带过滤参数.但只能选择子节点,不能选择孙子节点. find() 选取子节点,可以带过滤参数.可以选择子节点及孙子节点 ...
- JS获取子节点、父节点和兄弟节点的方法实例总结
转自:https://www.jb51.net/article/143286.htm 本文实例讲述了JS获取子节点.父节点和兄弟节点的方法.分享给大家供大家参考,具体如下: 一.js获取子节点的方式 ...
- JS-DOM ~ 03. 子节点的操作、style.样式和属性、dom元素的创建方法及操作、14个例题、主要是利用js直接控制html属性
带有Element和不带的区别 a) 带Element的获取的是元素节点 b) 不带可能获取文本节点和属性节点 获取所以子节点 a) . childNodes b) . children ...
- 5月25日-js操作DOM遍历子节点
一.遍历节点 遍历子节点 children();//获取节点的所有直接子类 遍历同辈节点 next(); prev(); siblings();//所有同辈元素 *find(); 从后代元素中查找匹配 ...
- jQuery操作DOM基础 - 创建节点
案例:创建两个<li>元素节点,并且作为<ul>元素节点的子节点,添加到DOM树中 <!DOCTYPE html> <html lang="en&q ...
- JavaScript DOM查询,原生js实现元素子节点的获取
在网页网页开发中,经常会需要获取某个网页元素的子元素,然后对其进行事件绑定.或样式修改等行为.这些操作对于jquery来说很容易,但是对于原生js会稍微麻烦一些,这里将介绍四种方法获取元素的子元素(本 ...
- JavaScript的DOM编程--04--获取元素节点的子节点
获取元素节点的子节点(**只有元素节点才有子节点!!) 1). childNodes 属性获取全部的子节点, 但该方法不实用. 因为如果要获取指定的节点 的指定子节点的集合, 可以直接调用元素节点的 ...
随机推荐
- Azure IoT
微软Azure IoT 国外物联网平台初探(二)——微软Azure IoT 马智 平台定位 连接设备.其它 M2M 资产和人员,以便在业务和操作中更好地利用数据. 连接 IoT 设备 将所有设备连 ...
- PHP之路——微信公众号授权获取用户信息
官方文档链接:http://mp.weixin.qq.com/wiki/4/9ac2e7b1f1d22e9e57260f6553822520.html /** * 获取code */ public f ...
- 【JavaScript】JavaScript教程之------------------JavaScript实现
JavaScript的核心ECMAScript描述了该语言的语法与基本对象: DOM描述了处理网页内容的方法和接口: BOM描述了与浏览器进行交互的方法和接口: 完整的JavaScript实现是由以下 ...
- SCALA常规练习B
package com.hengheng.scala class Point(val x : Int, val y : Int) { val isOriginal : Boolean = { x == ...
- 输入一个单向链表,输出该链表中倒数第K个结点
输入一个单向链表,输出该链表中倒数第K个结点,具体实现如下: #include <iostream> using namespace std; struct LinkNode { publ ...
- LINQ to SQLite完美解决方案
1.下载安装LinqConnectExpress(就是LinqConnect免费版) 2.安装好后就和LINQ TO SQL 一样了! 3.查询(增删改查和LINQ TO SQL 完全一样,你可以不 ...
- Hadoop的基本命令【转载】
在这篇文章中,我们默认认为Hadoop环境已经由运维人员配置好直接可以使用. 假设Hadoop的安装目录HADOOP_HOME为/home/admin/hadoop. 启动与关闭 启动HADOOP 进 ...
- 10个提升iOS开发效率的必用工具
Xcode插件 几乎所有开发者都知道Alcatraz是一个开源的包管理工具,可以让我们更轻松地管理各种插件.接下来就介绍下我的最推荐的10个插件: 10.HOStringSense 在编辑字符串的时候 ...
- int.Parse()与int.TryParse()
int i = -1;bool b = int.TryParse(null, out i);执行完毕后,b等于false,i等于0,而不是等于-1,切记. int i = -1;bool b = ...
- 关于CSS选择器的效率问题
最近一段时间接触CSS比较多,所以从网上找了写资料,这里做下总结. 以下是CSS选择器的效率排名: id选择器(#myid) 类选择器(.myclassname) 标签选择器(div,h1,p) 相邻 ...