作者:cleverpig

此图来源于1954年的《现代机械杂志》,图中展现了那时对2004年“家庭电脑”的预言
前言
2006年即将过去,这一年被广泛地看作是:在线投资新浪潮的一年;更新的web技术和技巧兴起和成长年;在采用web标准上增长年;从未这样采用web能量的新商务模式的兴起(和衰落)的一年。
从SitePoint和Ektron这两家组织提供的调查报告预览版中,其中的数据照射出在技术进化进程中的一丝亮光。大家不妨跟随作者一起放眼遥望一下亮光周围的风景,也许你会听到自己的惊呼,请加入到对“未来”的预言中吧!尝试一下网络对趋势的影响力!
关于SitePoint和Ektron进行的2006/2007 web开发现况调查
2006/2007 Web开发现状调查是在十年间致力于积极倡导和帮助web开发者、设计者和其它在线专业人员的SitePoint和Ektron共同进行的一项研究成果。
SitePoint是一家快速兴起的在线媒体公司和面向web专业市场(尤其在web开发和设计领域)的信息提供者。其网站:sitepoint.com,目前在全球web设计和开发>新闻和媒体分类的网站中排名列第一位,根据Alexa.com数据表明,其网站在全球排名位于前300名之内。Sitepoint.com的日访问量可与一些主流媒体集团的网站所匹敌。
SitePoint 论坛具有超过135000名注册用户,其新闻每月到达50万份订阅。SitePoint公司具有遍布于174个国家的70000名客户、试用产品的注册用 户高达620000名,具有五大收入来源:广告、赞助关系、基于内容的产品(包括在线和零售产品)、近来非常流行的视频订阅、分类列表和产业报告。
同样,Ektron有限公司成立于1998年,作为以CMS400.NET和eWebEditPro产品线为依托的web内容管理软件和web写作工具的技术和市场领导者,这些软件已经授权给千分之十的web专业人士,使他们更加高效地把web作为通讯和交互的有效平台。
SitePoint 和Ektron两者之间成熟的合作关系以及他们对web专业人士社团的支持,导致了在2006年初的idea:衡量在这两个组织周边的web开发者和其他 web从业人士这个大众群体,以便找出一个“时间快照”(snapshot in time)、量化web开发工具状况、技术、技巧和趋势。
在2006年6月15日至7月15日之间对5000名web从业人士进行了此项调查。我们相信这可能是有史以来最大规模的一次web开发者调查,这次调查的深刻意义之一就是反映当前现实状态和将要发生的变化。
Web标准的依从现状
CSS——轻舞飞扬的页面布局

图-1 采用CSS进行布局的分布图
评论:CSS布局不但对页面具有减肥的效果,而且对于统一风格、代码重用、浏览访问、打印颇有益处:
1.加快下载速度:





2.被更广泛地访问:
通过手持设备的浏览web用户数量正在与日俱增。在2008年PDA销售量将达到5千8百万(数据来源于eTForecast),世界三分之一的人口将拥有一台无线设备(数据来源于ClickZ)。而你可以编写专用于手持设备、额外的CSS文档——这个CSS文档内容可以取自以往的CSS文档。
有关内容可以参考:j2mepolish 的CSS for J2ME文档。
3.对搜索引擎更加友好:
搜索引擎在CSS驱动的页面中爬行要比在简单的HTML代码来得更容易。这样,搜索引擎可以对web页面进行更加有依据的猜测(比如:猜测页面的内容),所以使用CSS布局的web页面能够在搜索排行中拥有更高的排行。
有关内容可以参考:SE在线杂志。
4.打印友好:
当用户选择打印页面时,另一套可选的CSS文档可以被调用,这个文档可以规定格式、图片、隐藏导航、校正显示在打印版本中的页面内容。
验证HTML代码——多重浏览器标准的穿越者

图-2 应用web页面验证的分布图
评论:服从web标准将引领web站点走向成功,更友好地与搜索引擎“协作”、快速load页面、减轻Server负载、兼容众多浏览器、吸引更广泛的浏览量。
什么是HTML 验证(HTML validate)?
它是通过与标准HTML规则进行比较的方式,分析HTML文档、标记出错误和非标准代码的处理过程。Web页面使用HTML进行渲染,而HTML本身采用了HTML规范作为其规则和标准。
这里推荐两个权威的HTML验证在线服务:W3C的validator、WDG的validator。当然,在开发工具中的验证工具更不胜枚举:Dreamweaver内置验证器、Eclipse的WSVT等。
1.Web站点访问性:
验证HTML代码帮助你找出那些微小的不规范之处,从而防止它们妨碍搜索引擎爬虫或者浏览者。这样使你的站点获得更多的浏览者、更广泛的访问设备范围(手持设备、文本浏览器、搜索引擎等)。
2.对搜索引擎友好:
清晰、明快的代码可以使搜索引擎更快、更完整地页面中爬行。
3.更快速的装载:
如果你的页面包含了HTML错误,它将花费搜索引擎比较长的爬行时间,因此其排行位置也会变低。更加直观的是——如果你的页面在10秒内没有装载完毕,那么浏览者可能会离开。
4.减少服务器负载:
简明的代码不会像复杂的代码或者包含内嵌表格的代码那样让你的服务器负担加重。级联CSS将减少代码量,降低对web服务器空间的需要和对带宽的占有量、节省服务器的内存。
5.易于更新和维护站点:
无错的页面代码利于修改,这对于站点设计者来讲意味着节省时间和维护经费。
6.浏览器兼容性:
验证代码取保你的站点与当前的浏览器相兼容。既然我们无法预见未来的浏览器标准,那么验证代码就是把握未来浏览器标准的最佳方式。
7.更多的访问者:
保证了浏览器兼容性,也就赢得了大量的浏览者,从而获得更多的收益。
开发技术应用趋势
XP技术——潜力无限,业已成为技术热点

图-3 在web开发工作中进行实践的技术分布图
评论:OOP仍然是主流技术,尽管MVC占有不少的份额,但“用户体验才是产品的价值所在”这句话仍然得到了验证。无论任何技术理论(包括MVC、Ajax、RoR等),凡是能够高效地应用在快速开发、提高用户体验上的才是好技术。
Code review和Unit Testing都是极限编程(XP)中的概念,从图表中的比例来讲,让我感到欣慰:在开发技术中XP结对编程的方法得到了比较广泛的应用,希望国人也能更多的接受、应用它们。
什么是Code Review:在起始开发阶段对源代码语法检测,以期发现和修正错误、提高代码质量的活动,常称之为结对复查(peer review)。Code review经常可以发现和去除一些常见安全漏洞,比如格式化字符串攻击、竞争条件、缓冲区溢出,因此提升了软件的安全性。
什么是Unit Testing:单元测试是一种用来验证源代码的某个模块是否工作正常的活动。而每个测试实例都彼此独立;假对象(mock object)可以用于在隔离的环境下辅助测试某个模块。这样做目的在于把程序的每个部分分割开来、验证独立的部分是否正确。
采用结对编程可以在QA测试之前捕捉、修正错误,但不仅如此:
1.它使最终的错误内容下降到让人满意的程度,这源于采用持续的code review。
2.采用头脑风暴(brainstorm)和结对轮换(pair replay)使设计更加完善、代码长度更短。
3.依靠结对轮换团队解决问题更加迅速。
4.团队成员能够学习到关于系统和软件开发的更多知识。
5.项目结束时,多个团队成员能了解系统的每个部分。
6.成员在一起相互学习、谈话,提供了更好的信息流动和团队动力。
7.成员更加享受他们的工作,更加拥有成就感。
这种方式尤其适用于缺少人手或者短缺昂贵的专业测试系统和QA的开发团队。
工具流行趋势
Dreamweaver——web开发工具中的王者

图-4 web开发中采用的工具分布图
评论:DW能力十足,无论对于web设计者还是开发者来讲都是很顺手的工具,但其语法自动提示能力实在有限。而且对于开发者而言,DW的超强编辑能力也注定了它overkill的宿命,这也是Text Editor和它平分秋色的原因之一。
VS功能强大,但其受到微软语言的制肘,无法伸展开有力的上臂来拥抱各种开源语言。
这里我要遗憾地感叹一下Eclipse WTP,它提供的HTML 编辑器用上去还算可以,但相比之下相形见绌,不免有些鸡肋之嫌,还需要进一步完善:
1.Eclipse WTP的优点:





2.Eclipse WTP的缺点:




