JavaScript DOM编程艺术(第2版)学习笔记2(4~6章应用实例)
本书的第4章使用第3章学到的操作DOM的方法和属性写了一个展示图片的网页,并在第5,6章对代码进行了优化。
第一版,搭建网页的静态结构,包括一级标题<h1>,无序列表清单<ul>,每个列表<li>中又包括了链接<a>,当点击列表文字时会显示链接所指向的图片,这属于浏览器的默认行为。代码如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charest="utf-8"/>
<title>照片库</title>
</head>
<body>
<h1>My Photoes Gallery</h1>
<ul>
<li><a href="pictures/ASH1.png" title="空气弹簧">ASH</a></li>
<li><a href="pictures/LS1.png" title="片弹簧">LS</a></li>
<li><a href="pictures/MN1.png" title="磁负刚度">MN</a></li>
<li><a href="pictures/PAN.png" title="倒立摆">PAN</a></li>
</ul>
</body>
</html>
问题:显示图片后只能通过后退回到列表清单界面,希望实现图片与列表在同一界面,点击列表文字后直接将图片及说明显示在下方。
第二版,点击链接时直接将图片及说明显示在下方
操作步骤分为3步:
1,结构上添加图片占位符和文本占位符
2,js中写一个函数,用链接中的href属性替换图片占位符中的src属性,用链接中的title属性替换文本占位符的值
3,在html中相应节点上添加事件处理函数,应用js中所写的函数,注意需要阻止点击的默认行为
html代码如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charest="utf-8"/>
<title>照片库</title>
</head>
<body>
<h1>My Photoes Gallery</h1>
<ul>
<li><a href="pictures/ASH1.png" title="空气弹簧"
onclick="showPics(this);return false;">ASH</a></li>
<li><a href="pictures/LS1.png" title="片弹簧"
onclick="showPics(this);return false;">LS</a></li>
<li><a href="pictures/MN1.png" title="磁负刚度"
onclick="showPics(this);return false;">MN</a></li>
<li><a href="pictures/PAN.png" title="倒立摆"
onclick="showPics(this);return false;">PAN</a></li>
</ul>
<img id="placeholder" src="" alt="该图片已损坏或无法显示"/>
<p id="description">description of picture</p> <script src="ShowPics.js"></script>
</body>
</html>
js代码如下:
function showPics(whichPic){
//获取链接节点,获取图片节点,将链接节点中的href属性赋给图片节点中的src属性
var source=whichPic.getAttribute("href");
var myimage=document.getElementById("placeholder");
myimage.setAttribute("src",source);
//用链接节点中的title属性替换文本节点的值
var mytext=document.getElementById("description");
var context=whichPic.getAttribute("title");
mytext.firstChild.nodeValue=context;
}
注意:
1,在onclick事件中添加 return false;表示默认行为没有被触发即阻止了默认行为。
2,给图片占位符赋值时除了用setAttribute还可以用一种非DOM的方法,直接给元素的属性赋值 myimage.src=source,但这种方法并不适用于所有的属性,一般还是使用setAttribute,适用于所有属性。
3,给文本节点赋值时,需要注意修改的是p节点的第一个子节点,这个节点才是显示在界面上的文字。
4,src和href的区别
src(source)用引入的内容替换当前元素,常用于script,img,frame,
浏览器解析到该元素时会停止渲染知道文件加载完毕,所以将js文件放在body的最后;
href是一种引用,在当前文档与引用资源之间建立起一种联系,常用于a,link,
浏览器解析不会停止,所以用href引用css文件。
问题:
为提高代码的兼容性、可访问性,需要检查js功能被禁用时是否支持平稳退化;js与html是否完全分离;对DOM方法或使用到的元素是否存在进行检测
1,js代码没有与html完全分开,事件处理函数仍在html中
2,缺少必要的测试环节,如html中某些元素不存在
第三版:将事件处理函数从html中独立出来,该函数需要实现的功能:当点击某一链接时,将该链接传递给showPic()函数,去掉点击的默认行为
html代码只需要将onload函数去掉,在ul标签上加id属性
js代码如下:
function showPics(whichPic){
//增加测试
if(!document.getElementById("placeholder"))return false;
//获取链接节点,获取图片节点,将链接节点中的href属性赋给图片节点中的src属性
var source=whichPic.getAttribute("href");
var myimage=document.getElementById("placeholder");
myimage.setAttribute("src",source);
//用链接节点中的title属性替换文本节点的值,能否用nodeValue?可以,但是是p节点的第一个子节点的属性值
if(!document.getElementById("description"))return false;
var mytext=document.getElementById("description");
var context=whichPic.getAttribute("title");
mytext.firstChild.nodeValue=context;
}
function seperateclick(){
//1,测试当前浏览器是否理解DOM方法
if(!document.getElementById)return false;
if(!document.getElementsByTagName)return false;
var gallery=document.getElementById("picturegallery");
if(!gallery)return false;//疑问?能否先赋值再测试
//2,遍历列表中的所有链接,当某一链接被点击时,把这一链接传递给showPics函数,取消默认行为
//先将所有的链接存放在一个数组中
var links=gallery.getElementsByTagName("a");
//循环遍历
for(var i=0;i<links.length;i++){
links[i].onclick=function() {
showPics(this);
return false;
}
}
}
window.onload=seperateclick;
JavaScript DOM编程艺术(第2版)学习笔记2(4~6章应用实例)的更多相关文章
- 读书笔记:JavaScript DOM 编程艺术(第二版)
读完还是能学到很多的基础知识,这里记录下,方便回顾与及时查阅. 内容也有自己的一些补充. JavaScript DOM 编程艺术(第二版) 1.JavaScript简史 JavaScript由Nets ...
- Javascript DOM 编程艺术(第二版)读书笔记——基本语法
Javascript DOM 编程艺术(第二版),英Jeremy Keith.加Jeffrey Sambells著,杨涛.王建桥等译,人民邮电出版社. 学到这的时候,我发现一个问题:学习过程中,相当一 ...
- 《JavaScript DOM编程艺术(第二版)》读书总结
这本书是一本很基础的书,但对于刚入前端不久的我来说是一本不错的书,收获还是很大的,对一些基础的东西理解得更加透彻了. 1.DOM即document object model的缩写,文档对象模型,Jav ...
- 【读书笔记】读《JavaScript DOM 编程艺术-第2版》
1.DHTML DHTML曾被认为是HTML/XHTML.CSS和JavaScript相结合的产物,就像今天的HTML5那样,但把这些东西真正凝聚在一起的是DOM.如果真的需要来描述这一过程的话,“D ...
- JavaScript -- JavaScript DOM 编程艺术(第2版)
/* 渐进增强 平稳退化 网页 结构层(structural layer): HTML 表示层(presentation layer): CSS <link rel="styleshe ...
- Javascript DOM 编程艺术(第二版)读书笔记——DOM基础
1.DOM是什么 D=document(文档) O=object(对象) M=Model(模型) DOM又称节点树 一些术语: parent(父) child(子) sibling(兄弟) ...
- 《JavaScript DOM 编程艺术 第 2 版》
第 5 章 最佳实践 平稳退化:现在基本所有带交互的网站都使用 Ajax,SAP 也火起来了,平稳退化真是很难实现了(看到第七章发现我之前的观点是错了) 分离 JS 向下兼容 性能考虑 第 6 章 案 ...
- JavaScript DOM编程艺术读后感(1)—— 平稳退化
最近,在读<JavaScript DOM编程艺术(第二版)>这本书,想着将自己的读后感记录下来,作为记忆吧. 其实我并不是最近才刚开始读这本书的,我读了有一段时间了.我是一名web前端开发 ...
- JavaScript DOM编程艺术(第2版)的简单总结
介绍 JavaScript DOM编程艺术(第2版)主要讲述了 JavaScript.DOM 和 HTML5 的基础知识,着重讲述了 DOM 编程,并通过几个实例演示了具有专业水准的网页开发. 下面介 ...
- JavaScript DOM编程艺术学习笔记(一)
嗯,经过了一周的时间,今天终于将<JavaScript DOM编程艺术(第2版)>这本书看完了,感觉受益匪浅,我和作者及出版社等等都不认识,无意为他们做广告,不过本书确实值得一看,也值得推 ...
随机推荐
- 目标跟踪ObjectT综述介绍
此文也很详细:http://blog.csdn.net/maochongsandai110/article/details/11530045 原文链接:http://blog.csdn.net/pp5 ...
- 定时器篇---java.util.TimerTask和quartz
最近项目中出现了定时执行任务的东西,研究了一下,觉得挺不错的,以后还用得到,就总结了下. 这里只介绍两种java.util.Timer 和 quartz java.util.Timer java自带的 ...
- 【转】【Oracle 集群】Linux下Oracle RAC集群搭建之基本测试与使用(九)
原文地址:http://www.cnblogs.com/baiboy/p/orc9.html 阅读目录 目录 检查RAC状态 检查创建的数据库 全部参考文献 相关文章 Oracle 11G RAC ...
- Smallest Common Multiple FreeCodeCamp
题目:找出能被两个给定参数和它们之间的连续数字整除的最小公倍数. 范围是两个数字构成的数组,两个数字不一定按数字顺序排序. 分析:首先题目的意思求一个连续数列的所有数字的最小公倍数,这连续的数字序列 ...
- awk一次性分别赋值多个value给多个变量,速度对比
方法 #方法1: echo "apple banana orange" | awk '{print $1,$2,$3}' | while read a b c do echo a= ...
- Django入门--url路由基本配置
URL(Uniform Resoure Locater)统一资源定位符,是对可以从互联网上得到资源位置和访问方法的一种简洁形式,是互联网上标准资源的地址.互联网上的每个文件都有一个唯一的URL,它包含 ...
- Mybatis拦截器执行过程解析
上一篇文章 Mybatis拦截器之数据加密解密 介绍了 Mybatis 拦截器的简单使用,这篇文章将透彻的分析 Mybatis 是怎样发现拦截器以及调用拦截器的 intercept 方法的 小伙伴先按 ...
- 原生js,一些小应用(逢10进一,生成V字,多个div抖动)
第一题:每隔10个div换一行.并且鼠标移入 改变opacity. <!DOCTYPE html> <html lang="en"> <head> ...
- 数据库优化一般思路(PLSQL、Navicat)
SQL执行过程: 1.执行SQL时,sql解析引擎会被启动 2.数据类型和数据库表定义的数据类型不一致,数据库引擎会自动转化 3.数据库表定义了多个索引,sql引擎会帮你选择最优的一个 4.数据库引擎 ...
- Oracle中Cursor介绍和使用
版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/MyDreamNeverstop/article/details/78604033 一 概念 游标 ...