转行学开发,代码100天——2018-04-14

JavaScript中DOM操作基础知识即对DOM元素进行增删改操作。主要表现与HTML元素的操作,以及对CSS样式的操作。其主要应用知识如下图:

通过对DOM的基本了解,还要通过代码实现对DOM的操作。

1.childNodes + nodeType 与children的区别

  1. <ul id= "ull">
  2. <li>1</li>
  3. <li>2</li>
  4. <li>3</li>
  5. <li>4</li>
  6. <li>5</li>
  7. </ul>

通过对ul下li标签(也是本文中节点)获取,比较两者的不同

  1. //子节点
  2. var oUl = document.getElementById("ull");
  3. alert(oUl.childNodes.length); // 输出11 ,自动计算了文本元素(空)
  4. alert(oUl.children.length); //输出了5 ,不计算空文本,且只计算直接子节点

即childNodes 方法获取的子节点包含了空文本,而children方法获取的子节点不包括空文本,且只是父节点的直接直接点,即如果li节点下有其他元素,输出的结果也为5.

nodeType 返回节点的类型

如:

for (var i = 0; i < oUl.childNodes.length; i++) {
alert(oUl.childNodes[i].nodeType); //3/1交替出现
}

对于前面的HTML文档结构,循环输出的将是3,1,3,1...

由此也可以说明,通过childNodes获取到的节点包含了文本元素,即这里的空文本。

若改为children,则

for (var i = 0; i < oUl.children.length; i++) {
alert(oUl.children[i].nodeType);
}

输出的全是1,即全是元素。

因此,可以通过oUl.childNodes[i].nodeType == 1的判断,对元素进行单独操作。

2.父节点:parentNode与offsetParent

parentNode:获取元素的父节点

如:

  1. <ul id= "ull">
  2. <li>afs<a href="javascript:;">隐藏</a></li>
  3. <li>fdgd<a href="javascript:;">隐藏</a></li>
  4. <li>3sdfsd<a href="javascript:;">隐藏</a></li>
  5. <li>24rsdfsd<a href="javascript:;">隐藏</a></li>
  6. <li>tsdfasga5<a href="javascript:;">隐藏</a></li>
  7. </ul>

通过getElementsByTagName("a") 方法获取所有a节点,给a节点添加鼠标点击事件——隐藏。

通过当前a节点的父节点显示样式设置为“none”实现其整行隐藏。

  1. //父节点
  2. parentNode
  3. var oA = document.getElementsByTagName("a");
  4. // alert(oUl.parentNode);//body
  5. alert(oA.length);
  6. for (var i = 0; i < oA.length; i++) {
  7. oA[i].onclick = function()
  8. {
  9. this.parentNode.style.display = "none";
  10. }
  11. }

offsetParent :获取绝对定位元素的父节点。如果父节点没有绝对定位,则获取有绝对定位的父节点,直至body。

如下图父子方块

HTML&CSS

若div1无绝对定位,修改margin时,只是div1移动;若添加绝对定位position:relative时,修改margin时两个盒子相对移动。

绝对定位:

相对定位:

3.首位子节点

firstChild firstElementChild

lastChild lastElementChild

整两个获取子元素的方法有兼容性问题,(在使用时需要使用if语句进行判断)

oUl.firstChild.style.background ="red"; //ie7-ie8
oUl.firstElementChild.style.background = "red";//chrome ie9以上

因此,为了适用于多种浏览器,可以如下修改。

  1. var oUl = document.getElementById("ull");
  2. if (oUl.firstElementChild) {
  3. oUl.firstElementChild.style.background = "red";//chrome ie9以上
  4. }else{
  5. oUl.firstChild.style.background ="red"; //ie7-ie8
  6. }

///

其他子元素的操作如此类似。

day29—JavaScript中DOM的基础知识应用的更多相关文章

  1. javascript中DOM部分基础知识总结

    1.DOM介绍      1.1 DOM概念      文档对象模型(Document Object Model),它定义了访问和处理HTML文档的标准方法.现在我们主要接触到的是HTML DOM. ...

  2. javascript中BOM部分基础知识总结

    一.什么是BOM      BOM(Browser Object Document)即浏览器对象模型.      BOM提供了独立于内容 而与浏览器窗口进行交互的对象:      由于BOM主要用于管 ...

  3. JavaScript中BOM的基础知识总结

    一.什么是BOM      BOM(Browser Object Model)即浏览器对象模型.      BOM提供了独立于内容 而与浏览器窗口进行交互的对象:      由于BOM主要用于管理窗口 ...

  4. JavaScript中数组的基础知识和相关方法

      数组基础 数组是大多数语言里面最常见的一种数据结构,它是一个有序的值列表. 创建数组 1.创建字面量数组 let arr=[]; 2.创建构造函数数组 let arr=new Array(); 注 ...

  5. ASP.NET中的C#基础知识

    ASP.NET中的C#基础知识 说明:asp.net作为一种开发框架现在已经广为应用,其开发的基础除了前端的html.css.JavaScript等后端最重要的语言支持还是C#,下面将主要用到的基础知 ...

  6. MySQL中索引的基础知识

    本文是关于MySQL中索引的基础知识.主要讲了索引的意义与原理.创建与删除的操作.并未涉及到索引的数据结构.高性能策略等. 一.概述 1.索引的意义:用于提高数据库检索数据的效率,提高数据库性能. 数 ...

  7. javascript DOM 操作基础知识小结

    经常用到javascript对dom,喜欢这方便的朋友也很多,要想更好的对dom进行操作,这些基础一定要知道的.   DOM添加元素,使用节点属性  <!DOCTYPE html PUBLIC ...

  8. javascript中正则表达式的基础语法

    × 目录 [1]定义 [2]特点 [3]元字符[4]转义字符[5]字符组[6]量词[7]括号[8]选择[9]断言[10]模式[11]优先级[12]局限性 前面的话 正则表达式在人们的印象中可能是一堆无 ...

  9. Javascript中DOM技术的的简单学习

    第十四课DOM技术概述1:DOM概述 文档对象模型DOM(Document Object Model)定义访问和处理HTML文档的标准方法.DOM 将HTML文档呈现为带有元素.属性和文本的树结构(节 ...

随机推荐

  1. The second curriculum design experiment report in spring 2019

    2019年第二次课程设计实验报告 一.实验项目名称 贪吃蛇 二.实验项目功能描述 1.小蛇的移动 玩家可以通过 W A S D控制小蛇的上左下右移动,通过函数改变小蛇部位的位置 2.判断游戏失败 当小 ...

  2. Java-JavaMail邮件开发(1)Java Mail

    1.仅使用Java Mail 使用163邮箱作为代理服务器: 引入依赖: <dependency> <groupId>com.sun.mail</groupId> ...

  3. 如何配置属于自己的Git账户

    如何配置属于自己的Git账户:https://jingyan.baidu.com/article/3d69c55123e556f0cf02d730.html

  4. 使用userAgent区分浏览器版本

    使用userAgent区分浏览器版本:https://blog.csdn.net/n447194252/article/details/76255489 JS根据userAgent值来判断浏览器的类型 ...

  5. 经典的最大流题POJ1273(网络流裸题)

    http://poj.org/problem?id=1273 Drainage Ditches Time Limit: 1000MS   Memory Limit: 10000K Total Subm ...

  6. C# DataTable与实体的相互转换

    using System; using System.Collections.Generic; using System.Data; using System.Reflection; namespac ...

  7. http请求中的Content-Length作用机制与分块chunked

    httpclient-4.5.9.jar org.apache.http: auth     身份 client    端 conn     连接 cookie  本地 impl:    实现 exe ...

  8. d3与echarts的区别

    1. 目前各大公司的大数据平台多使用d3还是echarts?什么时候适合用echarts,什么时候适合用d3? 在我看几种数据可视化平台多使用折线图,面积图和柱状图,条图居多,对于echarts和d3 ...

  9. CentOS7搭建Flume与Kafka整合及基础操作与测试

    前提 已完成Kafka的搭建,具体步骤参照CentOS7搭建Kafka单机环境及基础操作 Flume安装 下载 wget http://mirrors.tuna.tsinghua.edu.cn/apa ...

  10. 2018-8-10-sublime-Text-正则替换

    title author date CreateTime categories sublime Text 正则替换 lindexi 2018-08-10 19:16:52 +0800 2018-2-1 ...