1、   DOM概念

全称为 Document Object Model,译为文档对象模型

D:文档 - DOM将HTML页面解析为一个文档 —> document对象

O:对象 - DOM将HTML页面中内容解析为对应的对象

M:模型 - DOM中对象之间的关系(节点树结构)

DOM的级别:0 级别:不是W3C的规范;    1、2、3级是W3C规范

l W3C对DOM的定义

DOM是一个独立于任何语言和平台的接口,允许任何语言或脚本动态地访问和更新HTML文档的内容、结构和样式。该HTML页面可以进一步处理,并且该处理的结果可以被合并到所呈现的HTML页面中。

l DOM的组成部分

DOM CORE;       DOM HTML;      DOM CSS;     DOM XML;

2DOM节点树

² DOM树结构

将HTML页面解析为一个树形结构

l 节点:

概念:树结构中每个连接的地方(元素、属性和文本)

(1)文档节点---表示整个HTML 页面(相当于document 对象)

(2)元素节点---表示HTML页面中的标签(即HTML页面的结构)

(3)属性节点:

(4)文本节点---表示HTML页面中的标签所包含的文本内容。

l  判断节点类型:

3、事件

概念:HTML页面或者浏览器窗口发生的一些交互瞬间

分类:键盘事件

键盘事件表示当用户操作键盘时发生。

onkeydown     用户按下一个按键; onkeyup    用户松开一个按键

onkeypress      键盘的按键按了一下( keydown + keyup 的组合)

oninput  输入事件

event事件对象提供哪些获取到有关键盘的属性

charCore 得到对应键盘的值-97

keyCode 得到对应键盘的值-97

which 得到对应键盘的值-97

注:三个event事件对象的属性,IE8及以下版本均不支持

key 得到对应键盘的值-a

鼠标事件

click 用户单击鼠标按键; dblclick     用户双击鼠标按键

mousedown     用户按下鼠标按键; mouseup    用户松开鼠标按键

mouseover       用户将鼠标移到指定标签上; mousemove       用户移动鼠标

mouseout 用户将鼠标从指定标签上移开

  • Ø 事件的执行流程:

获取 HTML 页面中指定的标签;为指定标签绑定指定事件;编写事件发生时的逻辑代码。

var 名称 = document.getElementById('id的名称');

名称.onclick=function( ){内容输出}

  • Ø HTML文档的加载:

想要在head里面运行script 需要head中script添加window.onload = function( ){ }

4Document对象

document对象作为DOM解析HTML页面的入口

u     DOM查询

² 优点:速度快,性能好; 缺点:单操作麻烦

getElementById( ):通过元素的id属性查找

注: 元素的id属性值必须是唯一的; 通过该方法获取的元素只能是唯一的

getElementsByName( ):通过元素的name属性查找

注: 元素的name属性不唯一,可能多个元素相同name属性; 通过该方法获取的元素可能是一个,也可能是多个。结构非常类似于数组的结构,但并不是一个数组。

结果类型—> NodeList(节点集合);类似于数组结构的对象—>类数组对象

getElementsByTagName( ) :通过元素的标签名查找

getElementsByClassName( ):通过元素class属性查找(新增方法,IE 8及以下浏览器不可

解决兼容性问题 -自定义函数

function getElementsByClassName(element,className){

if(document.getElementsByClassName){

}else{

}

}

² 优点:操作方便;      缺点:速度慢,性能差

querySelector( ) - 利用CSS选择器的用法

作用:返回与css选择器匹配的第一个元素

querySelectorAll( ) - 利用CSS选择器的用法

作用:返回与css选择器匹配的所有元素

u     NodeList类型

 

  • 动态NodeList

含义 - 获取的集合随着页面的变化而变化;   特点 - 执行速度快,耗时短

方法:getElementsByName( )   getElementsByTagName( )  getElementsByClassName( )

  • 静态NodeList

含义 - 获取的集合不会随着页面而变化;    特点 - 执行速度慢,耗时长

方法 - querySelectorAll()

u     创建节点:

² 元素节点 - createElement(‘标签名‘)

² 属性节点 - createAttribute(‘属性名‘)

步骤:                       [创建属性节点时,只能定义属性名,而不能定义属性值]

1. 创建属性节点: var attr = createAttribute(属性名)

2. 设置属性节点的值: attr.nodeValue = value;

3. 添加属性节点: A.setAttributeNode(B)    将B添加到A 上

注:属性节点不是一个子节点,不可用 ( A)appendChild(B )

² 文本节点 - createTextNode(文本内容)

  • Ø document对象属性(获取元素):

documentElement属性:获取页面中<html>;  即document. documentElement

head属性:获取页面中<head> ;    即document. head

body属性:获取页面中<body>;   即document. body

forms属性:获取HTML页面中所有的表单元素  即document. forms

images属性:获取HTML页面的图片元素      即document. images

DOM基础知识(概念、节点树、事件、Document)的更多相关文章

  1. HTML DOM基础知识

    HTML DOM基础知识 一.什么是DOM? 1.HTML DOM 定义了访问和操作HTML文档的标准方法. 2.HTML DOM 把 HTML 文档呈现为带有元素.属性和文本的树结构(节点树). 3 ...

  2. HTML DOM 基础知识,成为javascript晋级高手的必备手册

    一.DOM 简介,什么是 DOM? 文件对象模型(Document Object Model,简称DOM),是W3C组织推荐的处理可扩展置标语言的标准编程接口. 标记语言,也称置标语言,是一种将文本( ...

  3. DOM基础知识整理

    --<JavaScript高级程序设计>Chapter10学习笔记 一.节点层次 1.Node类型 1)(Node).nodeType属性 节点nodeType属性有12种. 检测node ...

  4. javascript中DOM基础知识介绍

    1.1.     基本概念 1.1.1.      DOM DOM Document Object Model 文档对象模型 就是把HTML文档模型化,当作对象来处理 DOM提供的一系列属性和方法可以 ...

  5. DOM基础+domReady+元素节点类型判断

    DOM节点类型  nodeType element  1    Node.ELEMENT_NODE   元素节点 attr  2   Node.ATTRIBUTE_NODE  属性节点 text  3 ...

  6. Javascript--HTML DOM基础知识

    1.HTML DOM是什么,以及它的作用: w3c对DOM有一系列的解释和定义,用自己理解的话来说就是:HTML DOM是html的标准对象模型,可以使JavaScript去操作(获取,修改,删除,添 ...

  7. DOM基础知识

    DOM BOMDOM 文档对象模型 document.BOM 浏览器界面上所有内容 broder object.没有括号属性.()方法 DOM写法 document.作用 做特效 找到 摘出元素 增删 ...

  8. DOM基础知识(Node对象、Element对象)

    5.Node对象 u  遍历节点 u 父节点 .parentNode - 获取父节点—> 元素节点或文档节点 .parentElement - 获取父元素节点—> 元素节点 u    子节 ...

  9. asp.net架构基础知识--页面以及全局事件

    1.asp.net的请求过程,以及对应的处理请求的dll客户的请求页面由aspnet_isapi.dll这个动态连接库来处理,把请求的aspx文件发送给CLR进行编译执行,然后把Html流返回给浏览器 ...

随机推荐

  1. VS2012编译PCL1.70的过程

    以防博主删除文档,重新copy一遍... 关于个人的几个注意事项: 对于boost,可以使用vc100的库,来编译VC110的代码: 对于确实的包含,一个一个添加,要耐心等待!!! 原文链接:http ...

  2. php生成唯一识别码uuid

    /*生成唯一标志*标准的UUID格式为:xxxxxxxx-xxxx-xxxx-xxxxxx-xxxxxxxxxx(8-4-4-4-12)*/ function uuid() { $chars = md ...

  3. 一系列令人敬畏的.NET核心库,工具,框架和软件

    内容 一般 框架,库和工具 API 应用框架 应用模板 身份验证和授权 Blockchain 博特 构建自动化 捆绑和缩小 高速缓存 CMS 代码分析和指标 压缩 编译器,管道工和语言 加密 数据库 ...

  4. PAT-树的同构

    链接 树的同构 题意 同构的定义: 给定两棵树T1和T2.如果T1可以通过若干次左右孩子互换就变成T2,则我们称两棵树是“同构”的. 给两棵树,判断是否同构 做法 先建树,然后判断,知道怎么判断就知道 ...

  5. day09网络编程

    一 操作系统基础 操作系统:(Operating System,简称OS)是管理和控制计算机硬件与软件资源的计算机程序,是直接运行在“裸机”上的最基本的系统软件,任何其他软件都必须在操作系统的支持下才 ...

  6. 洛谷P2296 寻找道路_简单BFS

    Code: #include<cstdio> #include<queue> #include<algorithm> using namespace std; co ...

  7. centos7安装nginx(基础篇)

    安装所需环境 Nginx 是 C语言 开发,建议在 Linux 上运行,当然,也可以安装 Windows 版本,本篇则使用 CentOS 7 作为安装环境. 一. gcc 安装安装 nginx 需要先 ...

  8. 别再问我ConcurrentHashMap了

    以下ConcurrentHashMap以jdk8中为例进行分析,ConcurrentHashMap是一个线程安全.基于数组+链表(或者红黑树)的kv容器,主要特性如下: 线程安全,数组中单个slot元 ...

  9. [SDOI2018]战略游戏(圆方树+虚树)

    喜闻乐见的圆方树+虚树 图上不好做,先建出圆方树. 然后答案就是没被选到的且至少有两条边可以走到被选中的点的圆点的数量. 语文不好,但结论画画图即可得出. 然后套路建出虚树. 发现在虚树上DP可以得出 ...

  10. vue 上传图片到阿里云(前端直传:不推荐)

    为何要这样做:减轻后端数据库压力(个人觉得于前端没啥用,谁返回来都行) 代码部分: <template> <div class="upLoad"> < ...