现代程序设计 网页前端开发作业(to 邹欣老师)

在一些著名的网站的搜索框上,会有一种“自动完成”功能。

 

比如google、百度和淘宝:

现在,我们来考虑如何实现这个功能。

 

第一步:模仿任意一个网站,编写一个类似的网页效果原型。

 

在这一步,不要估计开发时间。

把学习新技术(一些前端基础知识)的时间花在这个阶段。

以完成原型为目标,不必深入技术。

去 http://www.w3schools.com/ 获得入门知识

去 https://developer.mozilla.org/ 查阅文档

 

第二步:仔细观察三个网站的“自动完成”功能,比较它们<strong>功能</strong>的相同点和不同点,写成一份简单的需求分析文档。

请仅仅从功能角度分析这三个组件。

提示,如果你试图从代码中找到答案,你很可能陷入地狱。

除了界面,可以关注一些细节,比如键盘操作、响应时间。

第三步:设计并实现一个“自动完成”组件,使得它能够把三个网站的自动完成功能应付自如。

按照软件工程的模型进行设计、复审和实现。

在设计阶段,讨论清楚这个组件的用户需要面对的API:它们的命名、调用方式、编程风格、它所依赖的框架(如果有必要的话)。

尽量让使用变得简单。

尽量用可扩展性代替枚举需求。

根据第二步的需求来完成代码,不必试图跟原版"一模一样"。

考虑清楚如何管理这个组件用到的html、css和js代码。

第四步:找到另一个网站的自动完成功能,试试看我们的“自动完成”组件是否能够实现它!

如果可以实现,和小伙伴们讨论下,为什么你们的组件能够应对未知的需求?回顾设计阶段,哪些设计要素产生了关键性作用?

如果不可以实现,和小伙伴讨论下,为什么你们的组件无法应对新需求?需要做怎样的设计变更和代码重构,才能支持新的需求?

 

 

 

 

 

posted @ 2013-10-03 22:52  winter-cn  阅读(16432)  评论(12编辑  收藏  举报