技术很多,例子很多,只好慢慢学,慢慢实践!!现在学的这本书是【JavaScript实战----JavaScript、jQuery、HTML5、Node.js实例大全】

第 3 章 用 JavaScript 实现的照片展示

 

构建软件设计的方法有两种:一种是把软件做得很简单以至于明显找不到缺陷;另一种是把它 做得很复杂以至于找不到明显的缺陷。

——C.A.R.Hoare,1980 年图灵奖获得者

在这个自拍自恋的时代,照片是要展示的。在前面的章节里已经讲解了事件的绑定,本章主要利用前面的知识做一个照片展示的功能。

本章主要内容:

  • 照片的加载
  • 鼠标的响应
  • 键盘的响应

3.1  功能设计

功能设计的时候可能需要反复修改,以什么为标准呢?听老板的还是听用户的?虽然这是一个 顾客是上帝的时代,但终究还是有些设计原则要遵循,因为有时候“上帝”也会犯错误,更多的时候“上帝”是善变的。

(1)避免重复原则(DRY,Don’t repeat yourself),编程的最基本原则是避免重复,另一句 话说叫提高代码复用率。

(2)简单原则(Keep ItSimple and Stupid),简单是用户最佳体验之一,像苹果就是用简单 打败一切。而且简单的代码占用时间少,漏洞少,并且易于修改。

(3)低耦合原则(MinimizeCoupling),即这部分代码的使用和修改影响到其他部分的代码 尽可能的少,否则牵一发而动全身的悲剧无人愿意看到。

(4)别让我思考(Don’t make me think),代码不仅是写给机器的,更多是写给人看的,所以编写的代码一定要易于读易于理解,最终才易于维护。“如果一个维护者不再继续维护你的代码,

很可能他是有想杀了你的冲动。”

(5)单一责任原则(Single Responsibility Principle) ,某个代码的功能,应该保证只有单一的明确的执行任务,否则一旦修改会增加关联测试的繁琐程度。

(6)最大限度凝聚原则(Maximize Cohesion),尽量将功能相似相近的代码放在同一个部分。

程序中常听到的“类”这个词就取之于“物以类聚”,类就是为了“类聚”相似相近的代码。

(7)避免过早优化(AvoidPremature Optimization),现在社会到处都有“完美主义者”,如 果代码运行没有想象中的慢,就别去“完美”它,否则要花费更多的代价,或时间的或精力的或金钱的。

3.1.1 HTML、CSS 和 JavaScript 的分层关系

通过第 1 章的了解,HTML 是最早出来的,CSS和 JavaScript则稍晚出现。它们实质上的关系 应该是如图 3-1 所示。

图 3-1 UI 分层关系结构

看到这里似乎应该思考下前面的范例是否有“重构”的空间?答案是肯定的,笔者在写到第 2章时,本书编辑就很有意见地说:“咋这个代码这么长呢?能不能拆分成几块呢?„„”。 重构原因之一就是代码是否便于阅读。如果在设计时一开始就考虑进去,这会使后期的维护工作变得相对便捷,找 HTML 代码的就直接找 html 文件,找 JavaScript 代码的就直接找 js 文件,找CSS 代码的就直接找 css 文件。

将 JavaScript 和 HTML分离是前端必须要做的一种事。JavaScript 诞生是要让 HTML 更丰富, 而不是更杂乱。混合在一起会导致:bug 跟踪工具难以调试。随着分工更细分,写 HTML 的人不 一定要负责写 JavaScript。 CSS 和 HTML 一般也是分离的,不过这大都是网页设计师或者叫前端重构工程师的任务了。 另外保持 CSS 和 JavaScript 之间清晰的分离是很有挑战的,例如第 2 章的范例有控制 style.width的,还有控制 style.display 的,是否需要完全分离这确实需要具体情况具体分析,不过如果完全不注意这一点,任由其发展,一旦出现问题,大家首先去找 CSS,精疲力尽时才会去 JavaScript 中查 找样式问题,这会给维护人员挖下很大一个坑,做人一定要厚道!

3.1.2 照片展示功能设计

163 是国内早期提供相册功能的公司之一,相册用户群体很大,参考其相册会发现,照片展示 的基本功能如下:

  • 有大图和缩略图
  • 有上一张图和下一张图切换
  • 有键盘控制显示上一张图和下一张图
  • 有显示上一组和下一组功能在代码方面,考虑代码 3 层分离。

代码方面,考虑代码 3 层分离。

今天就先介绍到这里吧,有一起学习的小白们,欢迎粉我。

最具士兵突击实战类型的JavaScript

 JavaScript实战一书的基础知识部分帮助读者快速踏入JavaScript领域之门,jQuery部分帮助读者随心所欲地去工作,HTML5部分帮读者搭上时代的班车,Node.JS则可以让读者屹立在技术的前沿。笔者的目的就是力求写出最懂人性最懂技术的JavaScript书。

JavaScript、jQuery、HTML5、Node.js实例大全-读书笔记1的更多相关文章

  1. JavaScript、jQuery、HTML5、Node.js实例大全-读书笔记3

    技术很多,例子很多,只好慢慢学,慢慢实践!!现在学的这本书是[JavaScript实战----JavaScript.jQuery.HTML5.Node.js实例大全] JavaScript.jQuer ...

  2. JavaScript、jQuery、HTML5、Node.js实例大全-读书笔记2

    技术很多,例子很多,只好慢慢学,慢慢实践!!现在学的这本书是[JavaScript实战----JavaScript.jQuery.HTML5.Node.js实例大全] JavaScript.jQuer ...

  3. JavaScript、jQuery、HTML5、Node.js实例大全-读书笔记4

    5.2.2 让瀑布流动起来 打好基建之后,就需要写JavaScript代码.首先如果数据不够显示一屏幕的情况,就用新数据来补足它,在补充的时候是根据4列中最矮的那一个为优先补充,因为高矮尺寸一般只有在 ...

  4. Node.js高级编程读书笔记Outline

    Motivation 世俗一把,看看前端的JavaScript究竟能做什么. 顺便检验一下自己的学习能力. Audience 想看偏后台的Java程序员关于前端JavaScript的认识的职业前端工程 ...

  5. node.js开发指南读书笔记(1)

    3.1 开始使用Node.js编程 3.1.1 Hello World 将以下源代码保存到helloworld.js文件中 console.log('Hello World!'); console.l ...

  6. Node.js 开发指南-读书笔记

    1. Node.js 使用了单 线程.非阻塞的事件编程模式 Node.js 最大的特点就是采用异步式 I/O 与事件驱动的架构设计.对于高并发的解决方 案,传统的架构是多线程模型,也就是为每个业务逻辑 ...

  7. Node.js高级编程读书笔记 - 4 构建Web应用程序

    Outline 5 构建Web应用程序 5.1 构建和使用HTTP中间件 5.2 用Express.js创建Web应用程序 5.3 使用Socket.IO创建通用的实时Web应用程序 5 构建Web应 ...

  8. Node.js高级编程读书笔记 - 6 应用程序构建和调试 - Never

    Explanation 现阶段console.log(...),util.inspect(...), JSON.stringify(...)在控制台输出已经够用了[2015/07/19]. 单元测试隶 ...

  9. Node.js高级编程读书笔记 - 1 基本概念

    Outline 1 概述和安装 1.1 安装Node 1.2 Node简介 2 Node核心API基础 2.1 加载模块 2.2 应用缓冲区处理.编码和解码二进制数据 2.3 使用时间发射器模式简化事 ...

随机推荐

  1. WPF UI布局之概述

    在线演示:http://v.youku.com/v_show/id_XNzA5NDk2Mjcy.html 清晰版视频+代码下载:http://115.com/lb/5lbeer0m9lad 一.简单介 ...

  2. debian清除无用的库文件(清理系统,洁癖专用)

    deborphan 可以用来找出在系统中已经没有被依赖的套件.一般的情况是 library 会在其他套件需要的时候被牵引进来,但是当这些套件升级或删除后,被牵引进来的 library package  ...

  3. PHP做好防盗链的基本思想 防盗链的设置方法

    盗链是指服务提供商自己不提供服务的内容,通过技术手段绕过其它有利益的最终用户界面(如广告),直接在自己的网站上向最终用户提供其它服务提供商的服务内容,骗取最终用户的浏览和点击率.受益者不提供资源或提供 ...

  4. hdu1051 Wooden Sticks

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=1051 大意:求最少升序序列的个数. #include <cstdio> #include &l ...

  5. 嵌入式Linux开发系列之一: 走进嵌入式Linux的世界

    转载:http://www.ibm.com/developerworks/cn/linux/l-embed/part1/index.html   随着信息化技术的发展和数字化产品的普及,以计算机技术. ...

  6. JAVAMAIL手动发送邮件

    telnet smtp.sina.com 25ehlo hncu/*ehlo命令是SMTP邮件发送程序与SMTP邮件接收程序建立连接后必须发送的第一条SMTP命令,参数<domain>表示 ...

  7. .net 在不同情况下调用带soapheader的webservice的方式

    国庆长假到了,本想出去玩玩,无奈自己屌丝一枚,啥都没有,只能自己宅在家里思考思考人生.不过人生还是过于复杂,一时间也想不出个所以然,只能是整理一下在工作中遇到的一些小问题,首先是关于带soaphead ...

  8. ASP.NET MVC and jqGrid 学习笔记 5-添加数据

    据介绍,jqgrid有3种编辑数据的方式: Cell Editing 只允许修改某一个单元格内容 Inline Editing 允许在jqGrid中直接修改某一行的数据 Form Editing 弹出 ...

  9. iOS之Storyboard References

    如果你曾经使用 interface builder 创建过一个复杂.界面非常多的应用,你就会明白最后那些Storyboards 文件变的有多大.他会迅速变的无法管理,阻碍你的进度.自从引入 Story ...

  10. scrapy yield Request

    import scrapy from myproject.items import MyItem class MySpider(scrapy.Spider): name = ’example.com’ ...