《JavaScript Dom 编程艺术》读书笔记-第6章
本章继续对图片库进行改进,主要内容包括三个方面:
1. 把事件处理函数移出文档;
2. 向后兼容;
3. 确保可访问。
之前代码的HTML片段,此时如果浏览器不支持JS,图片显示也能正常工作,只是体验感降低。可见将“href”设置为真实存在的值,能够保证平稳退化。
<a href="image/2.jpg" onclick="showpic("image/2.jpg"); return false;"title="2" >2 </a>
考虑分离结构层(JS)和行为层。作为一条原则:如果想用JS给某个网页添加一些行为,就不应该让JS代码对这个网页的结构有任何期待。
function imagegallery(){
if (!document.getElementsByTagName){
return false; //检查是否有该方法
}
if(!document.getElementById){
return false;//检查是否有该方法
}
if(!document.getElementById("imagegallery")){
return false;//检查是否ID为imagegallery的元素
}
var gallery=document.getElementById("imagegallery");//找到该元素
var links=gallery.getElementsByTagName("a");//所以图片链接元素
for (var i=0; i<links.length;i++ )//遍历
{
links[i].onclick=function()//设置onclick函数
{
return !showPic(this);//取消元素点击的默认行为,传给showPic的参数是关键字this,他代表此时与onclick方法相关联的那个元素。
}
}
}
共享onload事件函数:addLoadEvent。
function addLoadEvent(func){
var oldload=window.onload;//把现有的onload函数存入到oldload
//alert(typeof oldload)
if (typeof oldload !='function')
{
window.onload=func;//如果oldload不是函数类型,那么之前没有函数绑定onload
}else{
window.onload=function(){
oldload();
func();
}
}
}
对于showPic函数,之前没有对它进行检查和测试。
function showPic(whichpic){
if (!document.getElementById("placeholder"))
{
return false//getElementById函数在imagegallery已经检查过,所以只需检查是否含有id=placeholder的元素。
}
var source=whichpic.getAttribute("href");
var placehold=document.getElementById("placeholder");
if (placehold.nodeName!='IMG')//nodeName总是返回一个大写字母的值,即时元素在HTML里是小写的
{
return false
}
placehold.setAttribute("src",source);
if (document.getElementById("describe"))//检查是否有describe元素,如果有
{
var tx=whichpic.getAttribute("title")?whichpic.getAttribute("title"):" ";//检查图片是否有title,有就修改,没有为空
var des=document.getElementById("describe");
if (des.firstChild.nodeType==3)
{
des.firstChild.nodeValue=tx;
}
}
return true;//如果切换成功放回TRUE,否则FALSE
}
把JS从HTML里分离出去还有一个好处,在把内嵌型事件处理函数移出标记文档是,在文档里为JS留下一个挂钩:
<ul id="imagegallery">
这个挂钩也可以用在CSS里。在html文件的<head>部分引用它:
<link rel="stylesheet" href="mywebCSS.css" type="text/css" media="screen"/>
DOM Core和HTML DOM:两种方法可以互换。
在js代码中遇到以下几个DOM方法:
getElementById
getElementsByTagName
getAttribute
setAttribute
这些方法书序DOM Core,并不属于js,任何一种支持DOM的语言都可以使用。
在JS和DOM为HTML文件编写脚本时,还有许多属性可以使用。比如onclick,用于图片库的事务管理。这些属性属于HTML-DOM。
比如:
document.getElementsByTagName("form")可以简化为document.forms。
element.getAttribute("src")可以简化为element.src。
HTML-DOM只能用来处理web文档。
本章的几个改进:
尽量不让JS代码依赖于哪些没有保证的假设,为此需要增加很多测试和检查。
没有使用onkeypress也能使JS代码的可访问性得到保证。
最重要的是,把事件处理函数从标记文档分离到一个外部JS文件中。
结构与行为的分离越大越好。
《JavaScript Dom 编程艺术》读书笔记-第6章的更多相关文章
- JavaScript DOM编程艺术读书笔记(三)
第七章 动态创建标记 在web浏览器中往文档添加标记,先回顾下过去使用的技术: <body> <script type="text/javascript"> ...
- JavaScript DOM编程艺术读书笔记(二)
第五章 最佳实践 平稳退化(graceful degradation):如果正确使用了JavaScript脚本,可以让访问者在他们的浏览器不支持JavaScript的情况下仍能顺利地浏览你网站.虽然某 ...
- JavaScript DOM编程艺术读书笔记(一)
第一章,第二章 DOM:是一套对文档的内容进行抽象和概念化的方法. W3C中的定义:一个与系统平台和编程语言无关的接口,程序和脚本可以通过这个接口动态的访问和修改文档的内容,结构和样式. DHTML( ...
- JavaScript DOM编程艺术 - 读书笔记1-3章
1.JavaScript语法 准备工作 一个普通的文本编辑器,一个Web浏览器. JavaScript代码必须通过Html文档才能执行,第一种方式是将JavaScript代码放到文档<head& ...
- JavaScript DOM编程艺术 读书笔记
2. JavaScript语法 2.1 注释 HTML允许使用"<!--"注释跨越多个行,但JavaScript要求这种注释的每行都必须在开头加上"< ...
- JavaScript DOM编程艺术读书笔记(四)
第十章 实现动画效果 var repeat = "moveElement('"+elementID+"',"+final_x+","+fin ...
- JavaScript DOM编程艺术-学习笔记(第二章)
1.好习惯从末尾加分号:开始 2.js区分大小写 3.程序界万能的命名法则:①不以,数字开头的数字.字母.下划线.美元符号 ②提倡以下划线命名法来命名变量,以驼峰命名法来命名函数.但是到了公司往往会身 ...
- 《javascript dom编程艺术》笔记(一)——优雅降级、向后兼容、多个函数绑定onload函数
刚刚开始自学前端,如果不对请指正:欢迎各位技术大牛指点. 开始学习<javascript dom编程艺术>,整理一下学习到的知识.今天刚刚看到第六章,记下get到的几个知识点. 优雅降级 ...
- JavaScript DOM编程艺术学习笔记(一)
嗯,经过了一周的时间,今天终于将<JavaScript DOM编程艺术(第2版)>这本书看完了,感觉受益匪浅,我和作者及出版社等等都不认识,无意为他们做广告,不过本书确实值得一看,也值得推 ...
- JavaScript DOM编程艺术-学习笔记
发现基础不是很好,补习一下.37买了2本书(dom编程和高级程序设计). 以前读书总是自己勾勾画画,有点没意思.现在写下来,说不定会成为传世经典.哈哈...........随便扯扯淡. 第一天(201 ...
随机推荐
- 18 os/os.path模块中关于文件/目录常用的函数使用方法 (转)
os模块中关于文件/目录常用的函数使用方法 函数名 使用方法 getcwd() 返回当前工作目录 chdir(path) 改变工作目录 listdir(path='.') 列举指定目录中的文件名('. ...
- jquery改变字符串中部分字符的颜色
//该方法改变字符串中中括号内(包括中括号)的字符串颜色为红色function changecolocer() { var zf = $('#YWFA').text(); if(zf.length&g ...
- Docker Weave 命令整理
Docker Weave 命令整理 # 查看weave状态 weave status # 查看状态详情 weave status connections # 查看weave相互之间节点建立的关系 we ...
- 使用curl自动签到smzdm
curl -H 'cookie:urcookies' -e 'http://www.smzdm.com/qiandao/' -k 'https://zhiyou.smzdm.com/user/chec ...
- linux基础之sed
sed: Stream EDitor,行编辑器 用法: sed [option]... 'script' inputfile... script: '地址命令' 常用选项: -n: 不输出模式中的内容 ...
- Windows Update Medic Service 拒绝访问
修改注册表:HEKY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\WaaSMedicSvc 中Start的值改为4.
- 【Git】Git使用记录: 撤回已经commit到本地的提交记录
话不多说直接上步骤: git bash直接干到你的code. 直接敲命令: git reset --soft HEAD~1 搞定 就是这么简单粗暴. 如有顾虑请自行找个案例测试即可. 参考资料 htt ...
- Java(1)JDK安装
1.安装JDK开发环境 下载网站:http://www.oracle.com/ 开始安装JDK: 修改安装目录如下: 确定之后,单击"下一步". 注:当提示安装JRE时,可以选择不 ...
- 51Nod - 1384
全排列函数解法 #include <iostream> #include <cstdio> #include <cstring> #include <cmat ...
- All You Can Code 2008 (Romanian Contest) A - Tree Search
A - Tree Search 思路: 经典树形dp dp[i][0]表示i的子树中以i为端点的最大链 dp[i][1]表是整棵树中除去i的子树剩下的部分以i为端点的最大链 最后答案就是以i为端点的最 ...