《DOM Scripting》学习笔记-——第八章 充实文档的内容
本章内容
一、一个为文档创建“缩略词语表”的函数
二、一个为文档创建“文献来源链接”的函数
三、一个为文档创建“快速访问键清单”的函数
利用DOM动态的收集和创建一些有用的辅助信息,并把它们呈现在网页上的基本思路:
1、把隐藏在属性里的信息检索出来(遍历、提取)
2、把这些信息动态的创建为一些html内容(创建元素节点、将内容插入元素节点)
3、把这些html内容插入到文档里(追加)
一、一个为文档创建“缩略词语表”的函数
Html代码:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN""http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8" />
<title>Explaining the Document Object Model</title>
</head>
<body>
<h1>What is the Document Object Model?</h1>
<p>
The <abbr title="World Wide Web Consortium">W3C</abbr> defines the <abbr title="Document Object Model">DOM</abbr> as:
</p>
<blockquote cite="http://www.w3.org/DOM/">
<p>
A platform- and language-neutral interface that will allow programsand scripts to dynamically access and update thecontent, structure and style of documents.
</p>
</blockquote>
<p>
It is an <abbr title="Application Programming Interface">API</abbr>that can be used to navigate <abbr title="HyperText Markup Language">HTML</abbr> and
19 <abbr title="eXtensible Markup Language">XML</abbr> documents.
</p>
</body>
</html>
命名:explanation.html
目的:创建“缩略词语表”,把html文档中<abbr>标签的title属性值收集起来,并将其集中显示在页面里。
具体步骤及实现方法:

js代码:
function displayAbbreviations()
{
if (!document.getElementsByTagName || !document.createElement
|| !document.createTextNode) return false;
// 获取abbr元素
var abbreviations = document.getElementsByTagName("abbr");
if (abbreviations.length < 1) return false;
var defs = new Array();
// 遍历abbr元素并获取abbr元素值及其title属性
for (var i=0; i<abbreviations.length; i++)
{
var current_abbr = abbreviations[i];
var definition = current_abbr.getAttribute("title");
var key = current_abbr.lastChild.nodeValue;
defs[key] = definition;
}
// 创建dl元素
var dlist = document.createElement("dl");
// 遍历abbr元素值及其title属性
for (key in defs)
{
var definition = defs[key];
// 创建dt元素、文本节点,将文本节点插入dt元素
var dtitle = document.createElement("dt");
var dtitle_text = document.createTextNode(key);
dtitle.appendChild(dtitle_text);
// 创建dd元素、文本节点,将文本节点插入dd元素
var ddesc = document.createElement("dd");
var ddesc_text = document.createTextNode(definition);
ddesc.appendChild(ddesc_text);
// 追加
dlist.appendChild(dtitle);
dlist.appendChild(ddesc);
}
// 创建大标题
var header = document.createElement("h2");
var header_text = document.createTextNode("Abbreviations");
header.appendChild(header_text);
// 将标题追加到html文档
document.body.appendChild(header);
// 将dl元素追加到html文档
document.body.appendChild(dlist);
}
二、显示“文献来源链接表”
收集和显示blockquote元素的cite属性所包含的信息:
(1)遍历这个文档里所有的blockquote元素。
(2)从blockquote元素提取出cite属性值
(3)创建一个标识文本是“source”的链接
(4)把这个链接赋值为blockquote元素的cite属性值
(5)把这个链接插入到文献节选的末尾
js代码
function displayCitations()
{
if (!document.getElementsByTagName || !document.createElement|| !document.createTextNode) return false;
// 获取所有的blockquote元素
var quotes = document.getElementsByTagName("blockquote");
//遍历所有blockquote元素
for (var i=0; i<quotes.length; i++)
{
// 如果节点没有cite属性,就跳转到下一次循环的开始,不再继续执行本次循环中的后续语句
if (!quotes[i].getAttribute("cite")) continue;
// 把cite属性值存入变量url
var url = quotes[i].getAttribute("cite");
// 获取所有的元素节点(不用lastChild,因为有些浏览器会把换行符当做文本节点)
var quoteChildren = quotes[i].getElementsByTagName('*');
/ /如果没有元素节点,就跳到下一次循环的开始
if (quoteChildren.length < 1) continue;
// 获取blockquote的最后一个元素
var elem = quoteChildren[quoteChildren.length - 1];
// 创建链接
var link = document.createElement("a");
var link_text = document.createTextNode("source");
link.appendChild(link_text);
link.setAttribute("href",url);
var superscript = document.createElement("sup");
superscript.appendChild(link);
// 追加
elem.appendChild(superscript);
}
}
三、显示“快速访问键清单”
编写一个能够把文档里用到的所有快速访问键显示在页面里的函数。
在html文档的<body>标签开头添加以下代码:
<ul id="navigation">
<li><a href="index.html" accesskey="1">Home</a></li>
<li><a href="search.html" accesskey="4">Search</a></li>
<li><a href="contact.html" accesskey="9">Contact</a></li>
</ul>
js代码如下:
function displayAccesskeys()
{
if (!document.getElementsByTagName || !document.createElement ||!document.createTextNode) return false;
// 获取文档中所有的links
var links = document.getElementsByTagName("a");
// 创建一个存储access keys的数组
var akeys = new Array();
// 遍历links
for (var i=0; i<links.length; i++)
{
var current_link = links[i];
//如果没有 accesskey属性,就跳到下一次循环
if (!current_link.getAttribute("accesskey")) continue;
//获取accesskey的value
var key = current_link.getAttribute("accesskey");
// 获取a的value
var text = current_link.lastChild.nodeValue;
// 把a的value和accesskey的value存入数组
akeys[key] = text;
}
// 创建list
var list = document.createElement("ul");
// 遍历accesskey的value
for (key in akeys)
{
var text = akeys[key];
// 创建要追加到list里的变量
var str = key + ": "+text;
// 创建list的内容
var item = document.createElement("li");
var item_text = document.createTextNode(str);
item.appendChild(item_text);
// 将list内容追加到list
list.appendChild(item);
}
// 创建标题
var header = document.createElement("h3");
var header_text = document.createTextNode("Accesskeys");
header.appendChild(header_text);
// 将标题追加到body
document.body.appendChild(header);
// 将list追加到body
document.body.appendChild(list);
}
addLoadEvent(displayAccesskeys);
小结:
需要对文档里的现有信息进行检索时,可用以下DOM方法:
getElementById()
getElementsByTagName()
getAttribute()
需要把信息添加到文档里时,可用以下DOM方法:
createElement()
createTextNode()
appendChild()
insertBefore()
setAttribute()
《DOM Scripting》学习笔记-——第八章 充实文档的内容的更多相关文章
- SpringBoot学习笔记:Swagger实现文档管理
SpringBoot学习笔记:Swagger实现文档管理 Swagger Swagger是一个规范且完整的框架,用于生成.描述.调用和可视化RESTful风格的Web服务.Swagger的目标是对RE ...
- 【Javascript DOM读书笔记】chapter8 充实文档内容
本章目的 作者举出了第一个实例,为一篇 web 页面动态创建缩略语(abbreviation)的列表.大家知道,我们可以使用 <abbr>...</abbr> 来指示一个缩略语 ...
- AngularJS1.X学习笔记14-动画(解读文档)
最近在看算法分析,那个大O啊,小o啊,分治法啊(目前就看到这里),真是搞死了.这回呢休息一下,学学AngularJS动画,上一篇文章根据自由男人的书简单谈到了动画的话题,发现反响很大(好吧,我说慌了, ...
- MongoDB学习笔记四—增删改文档下
$slice 如果希望数组的最大长度是固定的,那么可以将 $slice 和 $push 组合在一起使用,就可以保证数组不会超出设定好的最大长度.$slice 的值必须是负整数. 假设$slice的值为 ...
- MongoDB学习笔记三—增删改文档上
插入insert 单条插入 > db.foo.insert({"bar":"baz"}) WriteResult({ }) 批量插入 > db.fo ...
- HTML&CSS基础学习笔记1.4-定义文档类型
Web 世界中存在许多不同的文档.只有了解文档的类型,浏览器才能正确地显示文档. HTML 也有多个不同的版本,只有完全明白页面中使用的确切 HTML 版本,浏览器才能完全正确地显示出 HTML 页面 ...
- MongoDB快速入门学习笔记3 MongoDB的文档插入操作
1.文档的数据存储格式为BSON,类似于JSON.MongoDB插入数据时会检验数据中是否有“_id”,如果没有会自动生成.shell操作有insert和save两种方法.当插入一条数据有“_id”值 ...
- latex学习笔记----基本知识、文档排版
1.空格和制表符等空白字符视为相同的空白距离,多个连续的空白字符等同为一个字符. 2.# $ % ^ _ { } ~ 在这些字符前面加上反斜线,就可以在文本中得到它们. 反斜线\不 ...
- 吴裕雄--天生自然python学习笔记:python设置文档的格式
Win32com 组件可为特定范围的内 容设置格式, 较常用的格式有标题格式.对齐 方式格式及字体格式 . 许多格式使用 常量表示 , 所 以 需先导入 constants常量模块 : 设置标题格式的 ...
随机推荐
- 剑指offer 8.递归和循环 跳台阶
题目描述 一只青蛙一次可以跳上1级台阶,也可以跳上2级.求该青蛙跳上一个n级的台阶总共有多少种跳法(先后次序不同算不同的结果). 解题思路一: a.如果两种跳法,1阶或者2阶,那么假定第一次跳的是 ...
- 【转】/etc/rc.d/rc与/etc/rc.d/init.d的关系介绍
/etc/rc.d/init.d这个目录下的脚本就类似与windows中的注册表,在系统启动的时候执行.程序运行到这里(init进程读取了运行级别),相信从命名的角度大家也能猜到该运行/etc/rc. ...
- 表单数据转javabean对象
- docker整理
Docker的简单介绍 docker是什么 Docker 最初是 dotCloud 公司创始人 Solomon Hykes 在法国期间发起的一个公司内部项目,于 2013 年 3 月以 Apache ...
- Jenkins服务使用nginx代理服务器做负载均衡
学习nginx代理服务器做负载均衡的使用 在本地安装Nginx 1.下载nginx http://nginx.org/en/download.html 下载稳定版本,以nginx/Wi ...
- C语言数据结构基础学习笔记——树
树是一种一对多的逻辑结构,树的子树之间没有关系. 度:结点拥有的子树数量. 树的度:树中所有结点的度的最大值. 结点的深度:从根开始,自顶向下计数. 结点的高度:从叶结点开始,自底向上计数. 树的性质 ...
- (转)SQLServer_十步优化SQL Server中的数据访问四
原文地址:http://tech.it168.com/a2009/1125/814/000000814758_all.shtml 第八步:使用SQL事件探查器和性能监控工具有效地诊断性能问题 在SQL ...
- Xilinx FPGA开发随笔
1.UCF文件 1.1.UCF作用 UCF文件主要是完成管脚的约束,时钟的约束, 以及组的约束. 1.2.UCF语法 普通IO口只需约束引脚号和电压: NET "端口名称" LOC ...
- nfs与dhcp服务
NFS服务端概述 NFS,是Network File System的简写,即网络文件系统.网络文件系统是FreeBSD支持的文件系统中的一种,也被称为NFS: NFS允许一个系统在网络上与他人共享目录 ...
- 微信小程序之弹出操作菜单
<view class="List_count" bindtap="actioncnt"> <view class="img&quo ...