一.DOM简介

Document Object Model 文档对象模型

DOM包含了所有HTML元素的属性和方法,以及访问他们的方式;

#二.DOM节点

#1. 什么是节点?

HTML中所有的元素都是一个节点

整个文档是文档节点

所有的标签都是元素节点

标签内的属性是属性节点

标签内的文本是文本

IMG_256

#2. 节点属性

  Ele.nodeName Ele.nodeType Ele.nodeValue
元素节点 大写的标签名 1 null
属性节点 属性名 2 属性值
文本节点 #text 3 文本内容
注释节点 #comment 8 注释内容
文档节点 #document 9 null

***\ ** ** 元素的tagName等价于nodeName

#3. 节点关系

会识别空白文本(不常用)

元素.firstChild 第一个子节点

元素.lastChild 最后一个子节点

元素.childNodes 获取所有的子节点

元素.attributes 获取某个元素的所有属性节点

元素.nextSibling 获取下一个兄弟节点

元素.previousSibling 获取上一个兄弟节点

不识别空白文本

元素.children 获取所有的元素子节点

元素.firstElementChild 获取第一个元素子节点

元素.lastElementChild 获取最后一个元素子节点

元素.nextElementSibling 获取下一个元素兄弟节点

元素.previousElementSibling 获取上一个元素兄弟节点

元素.parentNode 父节点

#三.查找元素

语法:元素.getElementById(“id”)

功能:通过id名查找元素

返回值:DOM对象

语法:元素.getElementsByTagName(“tag”)

功能:通过标签名查找元素

返回值:类数组

语法:元素.getElementsByClassName(“class”)

功能:通过class名查找元素

返回值:类数组

语法:元素.querySelector("css选择器");

功能:根据css选择器查找,只找一个

返回值:DOM对象

语法:元素.querySelectorAll("css选择器");

功能:根据css选择器查找,找所有

返回值:类数组

类数组转数组:

**[... ** 类数组];

Array.from(类数组);

#四.元素类名

classList: 所有类名组成的类数组

classList.add() 添加类名

classList.remove() 删除类名

classList.contains() 检测类名是否存在,返回布尔值

classList.toggle() 类名存在则删除,类名不存在则添加

#五.课堂案例

#1. 选中高亮

效果图

img

功能思路分析:

\1. 给每一个li绑定点击事件(forEach)

\2. 点击事件中,利用排他思想,先去掉所有标签的类名

\3. 再给当前标签加上类名

#2.手风琴

效果图:

功能思路分析:

\1. 给每一个li绑定点击事件(forEach)

\2. 点击事件中,利用排他思想,先去掉所有标签的类名

\3. 再给当前标签加上类名

img

#3.选项卡

效果图

功能思路分析:

\1. 淡入淡出效果需要先将所有的图片定位在一起,修改他们的透明度(opacity)

\2. 给每一个导航信息绑定点击事件

\3. 点击事件中,利用排他思想去掉所有的类名,并找到对应下标的图片去掉类名

\4. 给点击的元素加上类名,并找到对应下标的图片加上类名(classList.add)

#六.今日小结

1.节点关系: firstElementChild lastElementChild

previousElementSibling nextElementSibling

children parentNode

2.查找元素: document.querySelector( ‘css选择器’)

document.querySelector( ‘css选择器’)

3.类名操作: classList.add() classList.remove()

classList.contains() classList.toggle()

#七.作业 -- 轮播图

将案例3选项卡改编成轮播图效果

\1. 加上定时器(setInterval)自动轮播

\2. 添加左右箭头,上一页下一页切换

js下 Day02、DOM文档对象模型的更多相关文章

  1. JS第二部分--DOM文档对象模型

    一.DOM的概念 二.DOM可以做什么 三.DOM对象的获取 四.事件的介绍 五.DOM节点标签样式属性的操作 六.DOM节点对象对值的操作 七.DOM节点-标签属性的操作(例如id class sr ...

  2. 认识DOM 文档对象模型DOM(Document Object Model)定义访问和处理HTML文档的标准方法。元素、属性和文本的树结构(节点树)。

    认识DOM 文档对象模型DOM(Document Object Model)定义访问和处理HTML文档的标准方法.DOM 将HTML文档呈现为带有元素.属性和文本的树结构(节点树). 先来看看下面代码 ...

  3. xml.dom——文档对象模型API

    文档对象模型,或者“DOM”,是一个跨语言API的World Wide Web Consortium(W3C)来访问和修改XML文档.DOM的实现提供了一个XML文档树结构,或允许客户机代码从头开始建 ...

  4. Javascript - DOM文档对象模型

    文档对象模型(DOM) DOM(Document Object Model,文档对象模型)是一个通过和JavaScript进行内容交互的APIJavascript和DOM一般经常作为一个整体,因为Ja ...

  5. JavaScirpt(JS)——DOM文档对象模型

    一.HTML DOM介绍 HTML DOM 是 W3C 标准(是 HTML 文档对象模型的英文缩写,Document Object Model for HTML). HTML DOM 定义了用于 HT ...

  6. JavaScript学习笔记7 之DOM文档对象模型

    一.什么是DOMDocument Object Model 文档 -------对象 ----模型-------缩写DOM DOM是针对HTML和XML文档的一个API(应用程序编程接口).DOM描绘 ...

  7. DOM 文档对象模型

    document 对象(作为对象),是 DOM 的核心作用:对内容,属性,样式等操作属性:title:设置/返回当前文档的标题url:返回当前文档的 urlinnerHTML:获取指定对象内的内容bg ...

  8. JavaScript学习总结(一)DOM文档对象模型

    一.文档(D) 一个网页运行在浏览器中,他就是一个文档对象. 二.对象(O) "对象"是一种自足的数据集合.与某个特定对象相关联的变量被称为这个对象的属性,只能通过某个对象调用的函 ...

  9. DOM文档对象模型

随机推荐

  1. 金九银十想面BAT?那这些JDK 动态代理的面试点你一定要知道

    一.什么是代理 代理是一种常用的设计模式,其目的就是为其他对象提供一个代理以控制对某个对象的访问.代理类负责为委托类预处理消息,过滤消息并转发消息,以及进行消息被委托类执行后的后续处理. 代理模式UM ...

  2. FL Studio 插件使用技巧——Fruity Reeverb 2 (上)

    许多学习FL的用户会发现,自己在听大师的电子音乐作品时都能感受到他们的音乐有一股强大的空间感,有时还能感知到深邃的意境.不少人会因此而疑惑:为什么出自我们之手的音乐就没有这样的效果呢?我们的音乐里到底 ...

  3. java基础:CompletionStage接口

    CompletionStage是Java8新增接口,用于异步执行中的阶段处理:先看接口 可以简单划分为三类: 1.在上一阶段执行结束之后,一阶段结果作为指定函数的参数执行函数产生新的结果,apply/ ...

  4. Contest 985

    A 均移到黑色或白色即可. 时间复杂度 \(O\left(n\log n\right)\). B 枚举每种开关判断是否有灯只能靠该种开关控制. 时间复杂度 \(O\left(nm\right)\). ...

  5. 方格取数(number) 题解(dp)

    题目链接 题目大意 给你n*m个方格,每个格子有对应的值 你从(1,1)出发到(n,m)每次只能往下往上往右,走过的点则不能走 求一条路线使得走过的路径的权值和最大 题目思路 如果只是简单的往下和往右 ...

  6. Java基础教程——线程同步

    线程同步 synchronized:同步的 例:取钱 不做线程同步的场合,假设骗子和户主同时取钱,可能出现这种情况: [骗子]取款2000:账户余额1000 [户主]取款2000:账户余额1000 结 ...

  7. Java基础教程——运算符

    运算符 算术运算符 加 减 乘 除 取余 自加 自减 + - * / % ++ -- public class 算术运算符 { public static void main(String[] arg ...

  8. idea使用帮助

    IDEA激活码形式,扫码二维码回复 激活码 自提,秒激活,持续更新.回复的是> 激活码 2020.2以上版本的 IDEA 请跳转至该链接:https://t.1yb.co/3ntg 2018.3 ...

  9. 倾斜摄影实景三维在智慧工厂 Web 3D GIS 数字孪生应用

      数字化推动钢铁工业转型升级 数字时代,随着数字地球,数字中国,数字工厂等数字化建设的不断深入,以地理信息系统(Geographic Information System, GIS)为基础,融合大数 ...

  10. Hbase 2.2.2 简单API操作

    前言 小案例中有创建表.创建命名空间.插入数据.获取数据. 环境准备 maven依赖可根据自己的版本进行调整 <!-- hbase依赖--> <dependency> < ...