ppk on JavaScript-背景革命三个层面分离表现和结构分离行为和结构

80酷酷网    80kuku.com

  javascript

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

革命

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

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

Unobtrusive脚本编程

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

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

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

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

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

三个层面

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

  1. HTML结构
  2. 表现
  3. 行为

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

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

分离的关系

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

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

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

分离表现和结构

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

更改

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

// obj is the form fieldobj.className += ' errorMessage';// in input.errorMessage {    border: 1px solid #cc0000;}

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

修改结构还是表现

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

分离行为和结构

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

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

分离文件中的函数

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

所以这是错误的:

<script type="text/javascript"> function doAllKindsOfNiftyThings() {     //  code } </script> </head> <body> <h1>My HTML page</h1> [etc.]

这才是正确的:

</head><body><h1>My HTML page</h1>[etc.]// 定义在分离的nifty.js中function doAllKindsOfNiftyThings(){    //  code}

删除事件处理句柄

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

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

<a href="home.html"  >Home</a>

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

<a href="home.html">Home</a>// in separate .js filevar nav = document.getElementById('navigation');var navLinks = nav.getElementsByTagName('a');for (var i=0;i<navLinks.length;i++){    navLinks[i].onmouseover = [code];    navLinks[i].onmouseout = [code];}

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

javascript:伪协议

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

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

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

<a href="somepage.html" id="nifty">Do Nifty!</a>// in separate .js filedocument.getElementById('nifty').onclick = doAllKindsOfNiftyThings;

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

[1]  



分享到
  • 微信分享
  • 新浪微博
  • QQ好友
  • QQ空间
点击: