《重构HTML:改善Web应用的设计(修订版)》——第2章 工具 2.1 备份、测试用机和源码控制

简介:

本节书摘来自异步社区《重构HTML:改善Web应用的设计(修订版)》一书中的第2章,第2.1节,作者: 【美】Elliotte Rusty Harold 更多章节内容可以访问云栖社区“异步社区”公众号查看。

第2章 工具

自动化工具是重构的重要组成部分。尽管可以使用文本编辑器手动执行重构,甚至有时出于演示的目的我也使用这种方式,但实际上绝大多数的时候我们都使用软件来辅助工作。据我所知,到本书写作时为止,还没有可用于HTML的主流的重构浏览器(refactoring browser)。但已经有很多工具可用在重构的过程中。本章会讲解一些工具。

2.1 备份、测试用机和源码控制

自始至终,我都会在本书中向你展示一些非常强大的工具和技术。伟大的教育家Stan Lee告诉我们:“能力越大,责任越大。”①使用这些技术必须对结果负责,不要让破坏变得不可弥补。我给你展示的工具中有些可能会“行为不端”,有些被弄糊涂时还有会出现边际效应。品质不良的HTML实在太多了,因此这里讨论的工具做不到面面俱到。因此,重构HTML至少需要5个步骤。

(1) 确定问题。

(2) 修复问题。

(3) 检验已修复的问题。

(4) 确保没有引入新问题。

(5) 部署解决方案。

错误在所难免,因此不要在任何一个在线的网站上使用这些技术。在做任何改动之前,先准备好一份网站的本地副本。完成本地副本的修改之后,仔细检查所有页面才进行部署。

现在许多大型网站都已经使用测试用机(staging server)或开发用机,在公开发布之前可以部署和检查内容。如果只是个人静态的小网站,直接复制一份到本地硬盘上进行修改就可以了。但无论如何都只在副本中工作,并在部署之前检查所有的变化。如何检查变化则是下一节要讲述的内容。

当然,就算是经过了最仔细的检查,还是难以避免一些错误,而这些错误由最终用户首先发现。有时网站在测试用机上运作得很好,但到了生产机中就有可能因为未知的配置区别,而碰到各种不可思议的问题。因此,对生产环境的网站进行整体备份,以便新部署的网站不能按预期运作时进行恢复,这是一个非常不错的做法。定期、可靠、经过测试的备份是不可或缺的。

最后,你应该非常谨慎地把包括HTML、CSS和图片的代码存储在源码控制系统中。程序员使用源码控制系统有数十年了,但Web开发者和设计者对它还相对陌生,现在是改变的时候了。网站越复杂,那些微乎其微的问题就越有可能被忽略。在重构时,能够恢复到前一个甚至是数月乃至数年之前的版本是非常关键的,这样才能找到是哪次改变引入了错误。源码控制同时提供以时间为标识的备份,因此可以还原到指定时间点的状态。

在Web开发中,我强烈推荐使用Subversion,很大程度上是因为它非常好地支持目录间文件的移动,并且对Unicode的出众支持和对二进制文件的得体支持也非常有帮助。大部分的源码控制系统在默认情况下都为程序员配置妥当,不用去关心文件在目录间的移动。但是Web开发者频繁地改变网站结构(实际上过于频繁了),因此系统必须能够追踪文件移动的历史。如果上级已经帮你配置了如CVS、Visual SourceSafe、ClearCase或者Perforce等其他源码控制系统,你大可随遇而安。但从长远看来,Subversion可能会做得更好,并且可以减少问题的引发。

如何管理Subversion这个主题可以写一本书,而实际上也已经有很多这样的书了(我喜欢的是Mike Mason著的Pragmatic Version Control Using Subversion[The Pragmatic Bookshelf,2006])。很多大型网站专门雇佣负责管理源码控制仓库的人。但先别担心,毕竟配置Subversion或其他源码控制仓库的难度,并不会超过配置Apache或其他Web服务器。只需阅读少量文档,修改某些配置文件,或者求助于新闻组,或者通过Google搜索就可以解决难题。这都是切实可行的,而且这些时间值得付出。

如果有必要,你可以使用命令行在Subversion中提交或获取文件。但如果能使用如BBEdit这种内置支持Subversion的编辑器,事情会变得更简单。如Dreamweaver这种本身不支持Subversion的编辑器也有插件支持Subversion。此外,像TortoiseSVN和SCPlugin这种有界面的产品,可以在Windows系统上的资源管理器或是Mac系统上的Finder上直接集成Subversion。

一些CMS(内容管理系统)也有内置的版本控制。如果你使用的CMS正好有版本控制,或许就没有使用外部仓库的必要了。比如,MediaWiki把所有页面的所有修改都存储起来,这样就可以查看指定页面在任何时间任何位置的状况,而且还能够还原。这是维基百科所安装的MediaWiki模块中很重要的一个,因为修改是一个很现实的问题。不过即便是不对外开放编辑权限的私有网站,也能在保存的完整的历史记录中得到好处。Wiki是Web中使用版本控制最普遍的一种,其他一些(如Siteline等)CMS也提供这样的功能。

相关文章
|
12天前
|
搜索推荐 定位技术 UED
HTML定位技术:种类、特点与应用
HTML定位技术:种类、特点与应用
|
14天前
|
测试技术 C语言
网站压力测试工具Siege图文详解
网站压力测试工具Siege图文详解
23 0
|
30天前
|
jenkins 测试技术 持续交付
现代软件测试中的自动化工具与挑战
随着软件开发领域的不断发展,自动化测试工具在测试过程中扮演着越来越重要的角色。本文将探讨现代软件测试中自动化工具的应用及面临的挑战,旨在帮助开发人员和测试人员更好地理解和应对自动化测试中的问题。
|
2天前
|
XML Web App开发 测试技术
python的Web自动化测试
【4月更文挑战第16天】Python在Web自动化测试中广泛应用,借助Selenium(支持多浏览器交互)、BeautifulSoup(解析HTML/XML)、Requests(发送HTTP请求)和Unittest(测试框架)等工具。测试步骤包括环境搭建、编写测试用例、初始化浏览器、访问页面、操作元素、验证结果、关闭浏览器及运行报告。注意浏览器兼容性、动态内容处理和错误处理。这些组合能提升测试效率和质量。
11 6
|
3天前
黑色个人主页HTML源码
黑色个人主页HTML源码,源码由HTML+CSS+JS组成,记事本打开源码文件可以进行内容文字之类的修改,双击html文件可以本地运行效果,也可以上传到服务器里面
24 6
黑色个人主页HTML源码
|
6天前
漂亮的七彩引导页导航HTML源码
漂亮的七彩引导页导航HTML源码,源码由HTML+CSS+JS组成,记事本打开源码文件可以进行内容文字之类的修改,双击html文件可以本地运行效果,也可以上传到服务器里面,重定向这个界面
2 0
漂亮的七彩引导页导航HTML源码
|
7天前
|
移动开发 HTML5
HTML5漫画风格个人介绍源码
HTML5漫画风格个人介绍源码,源码由HTML+CSS+JS组成,记事本打开源码文件可以进行内容文字之类的修改,双击html文件可以本地运行效果,也可以上传到服务器里面,重定向这个界面
11 0
HTML5漫画风格个人介绍源码
|
8天前
|
前端开发 搜索推荐 数据安全/隐私保护
HTML标签详解 HTML5+CSS3+移动web 前端开发入门笔记(四)
HTML标签详解 HTML5+CSS3+移动web 前端开发入门笔记(四)
18 1
|
9天前
|
PHP
web简易开发——通过php与HTML+css+mysql实现用户的登录,注册
web简易开发——通过php与HTML+css+mysql实现用户的登录,注册
|
12天前
2024个人导航HTML源码
2024个人导航HTML源码,源码由HTML+CSS+JS组成,记事本打开源码文件可以进行内容文字之类的修改,双击html文件可以本地运行效果,也可以上传到服务器里面,重定向这个界面
14 0
2024个人导航HTML源码