DOM可以将任何HTML和XML文档描绘成一个由多层次节点构成的结构。节点分为几种不同的类型,每种类型分别表示文档中不同的信息,每种类型都继承与Node接口,因此都共同享有一些属性和方法,同时,也拥有各自的特点、数据和方法。另外,每个节点都与其余节点存在一些关系。

一、节点树

以下面代码为例,先简单介绍一下:

<html>
<head>
    <title>Sample Page</title>
</head>
<body>
    <p>Hello world</p>
</body>
</html>

  这段代码的节点树表示如图(由三种类型的节点组成:Document/Element/Text):

二、节点共有的属性和方法

三、不同类型节点的介绍

1、Document类型

  document对象是Document类型的一个实例,表示整个html页面,并具有以下的属性和方法:

2、Element类型

  Element类型主要提供了对元素标签名、子节点和特性的访问。元素中所有指定的信息,可以通过以下代码来获取:

<html>
<head>
    <title>Sample Page</title>
</head>
<body>
    <div id="myDiv" class="bd" title = "Body text" lang = "en" dir = "ltr"></div>
<script>
    var div = document.getElementById("myDiv");
    alert(div.id);
    alert(div.className);
    alert(div.title);
    alert(div.lang);
    alert(div.dir);
</script>
</body>
</html>

  也可以通过操作DOM的方法来获取、修改、移除相应的属性,方法有:getAttribute()、setAttribute()、removeAttribute(),以getAttribute()为例:

<html>
<head>
    <title>Sample Page</title>
</head>
<body>
    <div id="myDiv" class="bd" title = "Body text" lang = "en" dir = "ltr"></div>
<script>
    var div = document.getElementById("myDiv");
    alert(div.getAttribute("id"));
    alert(div.getAttribute("class"));
    alert(div.getAttribute("title"));
    alert(div.getAttribute("lang"));
    alert(div.getAttribute("dir"));
</script>
</body>
</html>

3、Text类型

  文本节点由Text类型表示,包含的是可以照字面解释的纯文本内容。在默认情况下,每个包含内容的元素最多也只能有一个文本节点,而且必须有内容存在。

<!-- 没有内容,也就没有文本节点 -->
<div></div>

<!-- 有空格,因此有一个文本节点 -->
<div> </div>

<!-- 有内容,因而有一个文本节点 -->
<div>Hello World!</div>    

4、Comment类型

  注释在DOM中是通过comment类型来表示的。注释节点可以通过其父节点来访问:

<html>
<head></head>
<body>
    <div id="myDiv"><!--A comment--></div>
<script>
    var div = document.getElementById("myDiv");
    var comment = div.firstChild;
    alert(comment.data);
</script>
</body>
</html>

  另外,通过document.createComment()也可以创建注释节点。

5、CDATASection类型

  CDATASection类型只针对XML的文档,表示的是CDATA区域。

6、DocumentType类型

  DocumentType类型在web浏览器中并不常见,并且该类型的对象不能动态创建。

7、Document.Fragment类型

  Document.Fragment类型在文档中没有对应的标记,虽然不能把它直接添加到文档中,但是它可以作为一个“仓库”来使用,可以在里面保存将来会添加到文档中的节点。如下例所示,如果单独为<ul>元素添加3个列表项,将会导致浏览器反复渲染;通过文档片段来保存列表项,然后一次性的添加它们,可以避免这个问题。

<html>
<head></head>
<body>
    <ul id="myList"></ul>
<script>
    var fragment = document.createDocumentFragment();
    var ul = document.getElementById("myList");
    var li = null;
    for(var i = 0; i < 3; i++){
        li = document.createElement("li");
        li.appendChild(document.createTextNode("Item" + i));
        fragment.appendChild(li);
    }
    ul.appendChild(fragment);
</script>
    </body>
</html>

8、Attr类型

  Attr类型表示的是存在于元素属性中的节点,尽管它被认为是节点,但是并不存在于文档树中,通常使用getAttribute()、setAttribute()、removeAttribute()访问,很少直接引用Attr节点。

四、DOM操作技术

  DOM操作是JAVASCRIPT中开销最大的操作,以下介绍动态插入脚本、动态修改CSS样式。

1、动态脚本

<!-- 动态插入外部文件 -->
<script>
    function loadScript(url){
        var script = document.createElement("script");
        script.type = "text/javascript";
        script.scr = url;
        document.body.appendChild(script);
    }
    loadScript("client.js");
</script>
<!-- 直接插入javascript代码 -->
<script>
    function loadScriptString(code){
        var script = document.createElement("script");
        script.type = "text/javascript";
        try{
            // 如果出错,说明是IE
            script.appendChild(document.createTextNode(code));
        }catch(ex){
            script.text = code;
        };
        document.body.appendChild(script);
    }
    loadScript("function sayHi(){alert('Hi');}]");
</script>

2、动态样式

  动态样式是指页面刚加载时,不存在的样式;动态样式是在页面加载完后,动态添加到页面中的。

<!-- 动态插入外部样式表 -->
<script>
    function loadStyles(url){
        var link = document.createElement("link");
        link.type = "text/css";
        link.href = url;
        document.body.appendChild(link);
    }
    loadStyles("styles.css");
</script>
<!-- 直接插入样式代码 -->
<script>
    function loadStyleString(css){
        var style = document.createElement("style");
        style.type = "text/css";
        try{
            // 如果出错,说明是IE
            style.appendChild(document.createTextNode(css));
        }catch(ex){
            style.StyleSheet.cssText = css;
        };
        var head = document.getElementsByTagName("head")[0];
        head.appendChild(head);
    }
    loadStyleString("body{background-color:red}");
</script>

《JAVASCRIPT高级程序设计》节点层次和DOM操作技术的更多相关文章

  1. 【javascript学习——《javascript高级程序设计》笔记】DOM操作

    DOM(文档对象模型)是针对HTML和XML文档的一个API(应用程序编程接口).DOM描绘了一个层次节点树,允许开发人员添加.移除和修改. 1.节点层次 <html> <head& ...

  2. 《JavaScript高级程序设计》笔记:DOM(十)

    Node类型 nodeType以下是一些重要的nodeType的取值:1: 元素element2: 属性attr3: 文本text8: 注释comments9: 文档document nodeName ...

  3. 读书时间《JavaScript高级程序设计》五:DOM

    DOM(文档对象模型)是针对HTML文档的一个API,描绘了一个层次化的节点树,可以添加.移除.修改页面的某一部分. 一个简单的文档结构 <!DOCTYPE html> <html& ...

  4. 《JavaScript高级程序设计》笔记:DOM扩展(十一)

    选择符API querySelector()方法 // 取得body元素 var tbody = document.querySelector('body'); // 取得ID为"myDIV ...

  5. 《JavaScript高级程序设计(第3版)》阅读总结记录第一章之JavaScript简介

    前言: 为什么会想到把<JavaScript 高级程序设计(第 3 版)>总结记录呢,之前写过一篇博客,研究的轮播效果,后来又去看了<JavaScript 高级程序设计(第3版)&g ...

  6. 《JavaScript高级程序设计》读书笔记--前言

    起因 web编程过程使用javascript时感觉很吃力,效率很低.根本原因在于对javascript整个知识体系不熟,看来需要找些书脑补一下,同时欢迎众网友监督. 大神推荐书籍 看了博客大神们推荐的 ...

  7. 读书笔记(05) - 事件 - JavaScript高级程序设计

    HTML依托于JavaScript来实现用户与WEB网页之间的动态交互,接收用户操作并做出相应的反馈,而事件在此间则充当桥梁的重要角色. 日常开发中,经常会为某个元素绑定一个事件,编写相应的业务逻辑, ...

  8. 读书笔记(03) - 性能 - JavaScript高级程序设计

    作用域链查找 作用域链的查找是逐层向上查找.查找的层次越多,速度越慢.随着硬件性能的提升和浏览器引擎的优化,这个慢我们基本可以忽略. 除了层级查找损耗的问题,变量的修改应只在局部环境进行,尽量避免在局 ...

  9. javascript高级程序设计阅读笔记(一)

    javascript高级程序设计阅读笔记(一) 工作之余开发些web应用作为兴趣,在交互方面需要掌握javascript和css.HTML5等技术,因此读书笔记是必要的. javascript简介 J ...

随机推荐

  1. CodeForces 620C Pearls in a Row

    水题,每当出现重复就分割开来,最后留下的尾巴给最后一段 #include<cstdio> #include<cstring> #include<cmath> #in ...

  2. 子序列和问题 acm

    题目描述 给定一个序列 {a1,a2,…,an},定义从a[l]到a[r]的连续子序列的和为sum[l,r],即sum[l,r]=sigma{ai},l<=i<=r.(1<=l< ...

  3. MODBUS协议详解

    MODBUS是一个工业上通信常用的通讯协议,一般在PLC上面用的比较多,主要是定义了一种数据传输的规范,比如数据发给谁,数据是干嘛的,数据错没错,接收到数据的从机告诉我数据有没有接受到等. 传输的方式 ...

  4. java网络通信之非阻塞通信

    java中提供的非阻塞类主要包含在java.nio,包括: 1.ServerSocketChannel:ServerSocket替代类,支持阻塞与非阻塞: 2.SocketChannel:Socket ...

  5. IOS中APP开发常用的一些接口

    免费的API接口: 1.聚合数据,上面有手机归属地查询等: 2.百度API store:上面有很多免费的接口,可以使用在自己的app中: 3.环信:提供一些用户交互的一些场景等,可以用来做即时通讯软件

  6. Unity3d学习 基础-关于MonoBehaviour的生命周期

    其实在刚接触Unity3D,会有一个疑问,关于Unity3D游戏运行的初始入口在哪?不像Cocos2dx还有个AppDelegate文件可以去理解.而且在刚开始就接触Unity3D时,看到所有脚本中编 ...

  7. JSON详解(转载)

    JSON详解 阅读目录 JSON的两种结构 认识JSON字符串 在JS中如何使用JSON 在.NET中如何使用JSON 总结 JSON的全称是”JavaScript Object Notation”, ...

  8. margin的简单应用

    今晚学了盒模型的marg部分,简单仿下京东的官网首页部分 第一次制作,尽管看来实在惨不忍睹,毕竟娘不嫌儿丑,之后多加努力吧,这几天尽量加快学习进度,能单独制作一张精美的网页最好 附上代码 <!D ...

  9. iOS 开发 之 编程知识点

    iOS 创建和设置pch iOS 之 时间格式与字符串转换 iOS 之 二维码生成与扫描(LBXScan) iOS 之 定时器 iOS 之 通知 iOS 之 NSString 去除前后空格和回车键 i ...

  10. java 之 Spring 框架(Java之负基础实战)

    1.Spring是什么 相当于安卓的MVC框架,是一个开源框架.一般用于轻型或中型应用. 它的核心是控制反转(IoC)和面向切面(AOP). 主要优势是分层架构,允许选择使用哪一个组件.使用基本的Ja ...