`
stylezhao
  • 浏览: 6672 次
  • 来自: ...
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

ppk on JavaScript第二章:背景(一)

阅读更多

ppk on JavaScript第二章:背景(一)

JavaScript 为网页而存在,它会被嵌入到一个同时使用HTML和CSS的环境中,而此环境中不可缺少可用性和无障碍。总而言之,脚本必须给站点增加用处,而站点在 JavaScript失灵或者根本不存在的情况下依然能继续工作。兼容标准的CSS革命改变了Web开发,JavaScript编程也受到这场运动的巨大影响。

CSS革命

1998年,在Netscape和IE4无法达成任何协议时,一些先天下之忧而忧的Web开发者组成了 Web Standards Project(Web标准工程,简称WaSP),为解决JavaScript某些荒唐的私有元素,并推动使用CSS来定义网站的外观。她们的重要使命是“追随标准”,不仅针对浏览器厂商,而且号召Web开发者。

最初,WaSP及其支持者专注于CSS. 究其原因,CSS是一门比较新的技术,尚未被乱七八糟的东西污染,更容易成为历史的一个转折点,JavaScript就没有这么幸运了,那时候的 JavaScript,无论是编程,还是人们对它的想法,都是完全非无障碍的。这也是导致某些标准支持者产生“JavaScript就是障碍”观念的原因,无论是过去还是现在。其实,JavaScript和无障碍可以和谐共存,只要您稍微谨慎。

Unobtrusive脚本编程

2002年,Stuart Langridge创造出Unobtrusive脚本编程(unobtrusive scripting, Stuart Langridge的原文),这是首次重要的尝试——在基于CSS,标准兼容的新理论中嵌入JavaScript.

Unobtrusive脚本应该具备一下所有的特征:

  • 可用性,比如,赋予网站明确的可用性好处;
  • 无障碍,比如,假使JavaScript失效,页面应该保持可读和可理解,尽管不可避免地丧失某些可用性;
  • 容易实现,一个经典案例是,Web开发者只需把脚本引入和增加一个JavaScript调用钩子(hook),脚本就起作用;
  • 分离,属于本身的.js文件而不是散落在HTML的各个角落。

理论上说,第一条自JavaScript诞生之日起就有的,但是经常会被程序员在炫耀JavaScript能力的热忱中忽略。如果没有可用性多酷都无关紧要。

其他三条都是新的。通常都认为无障碍和JavaScript是互斥的。容易的实现需要JavaScript钩子,W3C DOM的降临使之成为可能。分离,是偷师于CSS革命的。如果需要分离HTML和CSS, 逻辑上,也应该把JavaScript从它们中分离。

三个层面

网页包含三个层次(没错,它们都需要各自分离):

3layers
  1. HTML结构
  2. CSS表现
  3. JavaScript行为

HTML结构层是网页最重要的基础。HTML标签给予内容含义。CSS表现层则是定义您的HTML该如何显示。JavaScript行为层为页面增加交互。

不管如何,一个网页必需HTML结构层。没有HTML,没有网页。CSS和JavaScript都是可选项,旧的,无名的,罕见的浏览器可能不支持 CSS和/或JavaScript,在这种情形下,这两层或其中一层都不起作用。后果是显而易见的,任何网站应能在行为层(或者表现层,但这种情形相比较少)的缺席下还能“存活”。也就是说,网站不能完全依赖于JavaScript,但要保证无障碍即使JavaScript不起作用。

分离的关系

一般来说,最好单独管理好每一层。最基础的,确保:

  • HTML是结构性的,不要太复杂,没有CSS和JavaScript下保持语义。
  • CSS表现层和JavaScript表现层分别归属于独自的.css.js文件。

分离更容易维护。您可以轻而易举地把分离的文件连接到整站的网页上,简单举个例子,您需要把字体从12px改成0.8em,您只需打开CSS文件编辑它,这样网页变化即刻生效。除此之外,分离让您可以不需修改HTML结构层或者JavaScript行为层,只需修改整个CSS表现层就可让网站换上新衣。

分离表现和结构

表现和结构分离的基本思想是确保HTML定义结构,只有结构,所有的表现都定义到分离的CSS文件中去。不再允许font标签或者表现性的表格!在一本JavaScript的书中似乎没有什么余地来探讨CSS和HTML的分离。那么我们就来说说这个分离对我们编写JavaScript代码方式的影响吧。

CSS更改

JavaScript可以让您修改CSS,比如,您可以在CSS定义一个连接为红色,然后用JavaScript控制CSS再定义为绿色。有时候这是很有用的,样式的变化会使用户能注意变化的HTML的元素,比如出错信息。如果没有正确地分离CSS表现层,CSS更改将会变得十分困难。改变元素的className通常是最佳的CSS更改方式。如下例子,假如表单验证程序发现用户输入错误,则改变该表单字段的class:

// obj is the form field
obj.className += ' errorMessage';

// in CSS
input.errorMessage {
    border: 1px solid #cc0000;
}

只有您正确分离了表现和结构,这样的方式才会起作用。class errorMessage必须定义在CSS中为了实现样式的更改,反过来,也只有您一开始就从正确的CSS表现层开始才有可能(或者说,可行)。

修改结构还是表现

JavaScript实际上允许您改变网站的表现,也允许您改变HTML文档。用户并不关心我们改了什么。但还是有所不同的。改变一个应答用户行为的表单应该是修改结构而不是表现。相关表单元素不应该只是从视觉上隐藏而已,而应该从文档结构中移除。当一个表单提交时,浏览器为所有表单元素创建名称/ 值配对,并发送给服务器。如果仅仅是在CSS中隐藏,这些字段依然是表单的组成部分,尽管可能不是服务器所需要的。这只是理论上的东西,您可以不同意我。

分离行为和结构

分离行为与结构很容易理解:不要把任何JavaScript代码写入HTML页面中。采取这两步:

  • 把所有的JavaScript函数定义在一个分离的.js文件中,让所需的HTML页面连接到它。
  • 删除所有的事件处理句柄(注:即行内的那些诸如onmouseover)并归入同一.js文件中去。

分离文件中的函数

JavaScript代码属于.js文件,而非HTML文件。

所以这是错误的:

<script type="text/javascript">
 function doAllKindsOfNiftyThings()
 {
     // JavaScript code
 }
 </script>
 
xml 代码
  1. <script type="text/javascript">  
  2.  function doAllKindsOfNiftyThings()   
  3.  {   
  4.      // JavaScript code   
  5.  }   
  6.  script>  
  7.  head>  
  8.  <body>  
  9.  <h1>My HTML pageh1>  
  10.  [etc.]  

这才是正确的:

xml 代码
  1. head>  
  2. <body>  
  3. <h1>My HTML pageh1>  
  4. [etc.]   
  5.   
  6. // 定义在分离的nifty.js中   
  7. function doAllKindsOfNiftyThings()   
  8. {   
  9.     // JavaScript code   
  10. }  

删除事件处理句柄

第二步是把所有HTML内的JavaScript函数调用移到分离的.js中去。事实上,99%的HTML内的JavaScript代码是行内事件句柄。

以下,句柄在HTML内,但不应该属于HTML的:

xml 代码
  1. <a href="home.html" onMouseOver="mOv('home')" onMouseOut="mOut('home')">Homea>  

应该定义在分离的.js文件中去:

  1. <a href="home.html">Homea>  
  2. // in separate .js file   
  3. var nav = document.getElementById('navigation');   
  4. var navnavLinks = nav.getElementsByTagName('a');   
  5. for (var i=0;i<navLinks.length;i++)   
  6. {   
  7.     navLinks[i].onmouseover = [code];   
  8.     navLinks[i].onmouseout = [code];   
  9. }  
xml 代码

该脚本处理id="navigation"的元素并处理其内的所有连接,然后再赋予连接事件处理句柄。

javascript:伪协议

有些情况下你会看到像以下的javascript:伪协议:

  1. <a href="javascript:doAllKindsOfNiftyThings()">Do Nifty!a>  

这个复杂肮脏代码隐藏的含义是一个onclick事件句柄:当用户点击该连接,我们需要的是呼叫doAllKindsOfNiftyThings()函数。所以您应该从该连接中删除javascript:呼叫而用一个独立.js文件中的onclick事件句柄来取代之:

xml 代码
  1. <a href="somepage.html" id="nifty">Do Nifty!a>  
  2. // in separate .js file   
  3. document.getElementById('nifty').onclick = doAllKindsOfNiftyThings;  

因此,对于href,应该包含一个完整的url以备没script的用户能够访问,否则整条连接都由JavaScript产生,不具备无障碍性。

http://realazy.org/blog/2006/12/21/ppk-on-javascript-study-note-part02-1/

 

xml 代码
评论
2 楼 yz_beijing 2007-03-21  
zeg 写道
event hook本来就应该用inline的

把事件注册放在js文件里只能为开发和调试带来障碍

完全彻底割裂设计和编程没有任何好处
up up
1 楼 zeg 2007-03-16  
event hook本来就应该用inline的

把事件注册放在js文件里只能为开发和调试带来障碍

完全彻底割裂设计和编程没有任何好处

相关推荐

    ppk on javascript

    《ppk on JavaScript》是JavaScript领域的经典之作,由Peter-Paul Koch(简称ppk)撰写。这本书深入浅出地探讨了JavaScript语言的核心概念和技术,对于任何想要深入理解JavaScript的开发者来说,都是一份不可多得的...

    《ppk谈JavaScript》中文版pdf和原书示例源码

    ppk谈JavaScript JavaScript入门必读之书 本书全方位介绍了JavaScript,主要讨论了浏览器兼容性、可访问性、底层语法以及与HTML结构层的协同等问题。书中既包括理论性的讲解,又给出了相关的示例脚本以进行进一步...

    ppk on Javascript (pdf)

    #### 二、上下文与背景 1. **CSS革命**:随着CSS的出现和发展,网页设计发生了根本性的变化,不再仅仅依赖于内联样式和JavaScript来控制页面布局。 2. **结构与表现分离**:将CSS用于控制网页的表现形式,而将...

    ppk谈JavaScript.pdf

    4. **DOM操作**:JavaScript能够操作文档对象模型(DOM),用于动态更新网页内容,包括元素选择(getElementById, getElementsByClassName, querySelector, querySelectorAll等)、属性修改、事件处理、节点操作...

    PPK谈JavaScript[扫描版]

    #### PPK谈JavaScript背景 - **作者介绍**:PPK(Peter-Paul Koch)是知名的前端开发者、讲师及顾问,专注于浏览器兼容性和移动设备浏览器的研究。 - **书籍定位**:《PPK谈JavaScript》是一本深入探讨JavaScript...

    JavaScript(ppk谈JavaScript+JavaScript语言精粹修订+Secrets of the JavaScript Ninja)

    标题中的“ppk谈JavaScript”可能指的是Peter-Paul Koch(ppk)的一本书,他在JavaScript社区中是一位知名专家,特别在移动浏览器和跨平台兼容性方面有深入研究。ppk的书籍通常会涵盖JavaScript的基础知识,以及如何...

    ppk谈JavaScript PDF

    本书全方位介绍了JavaScript,主要讨论了浏览器兼容性、...通过8个真实项目示例,介绍了JavaScript核心语言、BOM、事件处理、DOM、修改CSS样式表以及数据检索等内容。 本书适合具有一定网页开发经验的Web开发人员阅读。

    ppk谈javascript源码

    《ppk谈JavaScript源码》是一本探讨JavaScript编程精髓的著作,由知名Web开发者Peter-Paul Koch(简称ppk)撰写。在这个压缩包中,包含了书中的一些关键示例的源代码,这对于学习和理解JavaScript的实际应用非常有...

    new.riders.press.ppk.on.javascript.sep.2006.chm

    《PPK on JavaScript》是由Peter-Paul Koch(PPK)撰写的一本关于JavaScript的书籍,出版于2006年9月。这本书是JavaScript开发者的重要参考资料,尤其对于那些想要深入理解JavaScript核心概念和技术的读者来说更是...

    new.riders.press.ppk.on.javascript.sep.2006.rar

    《PPK on JavaScript》是由Peter-Paul Koch(PPK)撰写的一本关于JavaScript的书籍,出版于2006年9月,由New Riders Press发行。这本书深入浅出地探讨了JavaScript这一重要的Web开发语言,涵盖了从基础到高级的各种...

    ppk谈javascript示例源码

    6. **对象和数组**:JavaScript的对象是一种键值对的集合,而数组则是一系列元素的集合。示例将展示如何创建、访问和修改对象属性,以及数组元素。 7. **DOM操作**:ppk在书中也会涉及JavaScript如何与HTML文档对象...

    ppk谈JavaScript.part07.rar

    1. **闭包**:JavaScript中的闭包是一种强大的特性,它允许函数访问并操作其外部作用域的变量,即使在其外部作用域已经被销毁的情况下。闭包常用于数据封装、模块化和内存管理。 2. **原型链**:JavaScript对象基于...

    ppk谈JavaScript.part01.zip

    "ppk谈JavaScript.part01.zip"很可能包含的是Ppk关于JavaScript的系列文章或教程的第一部分,它可能涵盖了JavaScript的基础知识、最佳实践以及一些Ppk的独特见解。 JavaScript的核心概念包括变量、数据类型、控制...

    PPK谈javascript示例

    在JavaScript编程领域,PPK(Peter-Paul Koch)是一位知名专家,他的著作《PPK谈JavaScript》深入浅出地介绍了JavaScript的核心概念和技术。本部分将分析提供的代码示例,主要涉及两个方面:文本输入区的长度限制和...

    PPK on Javascript

    原作者为Peter-Paul Koch(即ppk)他是自学成才的世界级JavaScript专家,1970年生于荷兰阿姆斯特丹,大学主修古希腊罗马史专业。他拥有多年客户端web开发经验,所维护的网站www.quirksmode.or9已成为全球JavaScript...

    ppk谈JavaScript.part02.zip

    "ppk谈JavaScript.part02.zip"可能是一个系列教程或讲座的第二部分,由ppk(Peter-Paul Koch)分享。ppk是一位知名的前端开发者,以其对浏览器兼容性和移动Web开发的深入研究而闻名。在这个部分中,他可能会继续探讨...

    ppk谈JavaScript.part04.rar

    《ppk谈JavaScript.part04》是关于JavaScript编程的一个系列教程的第四部分,由知名前端开发者Peter-Paul Koch(简称ppk)撰写。这个部分很可能深入探讨了JavaScript的高级概念和实战技巧,对于想要深入了解这门语言...

    ppk谈JavaScript.part03.rar

    3. **对象和原型链**:JavaScript采用原型继承模型,每个对象都有一个原型对象,可以通过__proto__属性或Object.getPrototypeOf方法访问。原型链使得对象可以共享属性和方法,实现继承。 4. **事件和事件处理**:...

Global site tag (gtag.js) - Google Analytics