JavaScript设计模式

相关资料

[

认识张容铭是在2012年年底的时候,那时张容铭来公司实习,大家都觉得这小伙子实力不俗。而且很爱钻研。在得知容铭利用业余时间完成了本书的创作,作为他的朋友,真替他感到高兴!短短几年,进步如此迅速,在前端实战开发方面有着这么多的积累,有时也会让我自愧不如。
  在web应用日益丰富的今天,越来越多的javascript被运用在我们的网页中。随着用户体验日益受到重视,前端的可维护性、前端性能对用户体验的影响开始备受关注,因此如何编写高效的可维护的代码,成为众多互联网公司争相研究的对象。
  本书通过对话的方式详细地介绍了各种设计模式的原则和准确定义、应用方法和最佳实践,全方位比较各种同类模式之间的异同,详细讲解不同模式的使用方法。
  “极具趣味,容易理解,但讲解又极为严谨和透彻”是本书的写作风格和最大特点。希望大家在学到知识的同时,能够感受到作者的风趣幽默。
  最后,希望本书能够帮助业界同仁打造出更为卓越的web产品。
  阿里巴巴集团(淘宝) 高级web前端研发工程师 王鹏飞
  在百度工作的时间里,和张容铭共事过一段时光,在相处的过程中就发现张容铭对设计模式的研究和应用有很大的热情,投入精力很多,且在应用上有很好的理解和收获。本书可以说是张容铭多年来积累的技术经验的总结,涵盖了绝大多数设计模式;叙述方面采用新人与导师对话的方式,风趣幽默、通俗易懂,非常适合javascript初学者和前段开发工程师学习。
  百度 高级前端研发工程师 杨坤

,

 

]

本书特色

[

《javascript设计模式》共分六篇四十章,首先讨论了几种函数的编写方式,体会javascript在编程中的灵活性;然后讲解了面向对象编程的知识,其中讨论了类的创建、数据的封装以及类之间的继承;*后探讨了各种模式的技术,如简单工厂模式,包括工厂方法模式、抽象工厂模式、建造者模式、原型模式、单例模式,以及外观模式,包括适配器模式。本书还讲解了几种适配器、代理模式、装饰者模式和mvc模式,讨论了如何实现对数据、视图、控制器的分离。在讲解mvp模式时,讨论了如何解决数据与视图之间的耦合,并实现了一个模板生成器;讲解mvvm模式时,讨论了双向绑定对mvc的模式演化。本书几乎包含了关于javascript设计模式的全部知识,是进行javascript高效编程**的学习手册。
  《javascript设计模式》适合javascript初学者、前端设计者、javascript程序员学习,也可以作为大专院校相关专业师生的学习用书,以及培训学校的教材。

 

]

内容简介

[

专业讲解全面web前端设计模式书
  阿里巴巴、百度前端高级工程师鼎力推荐
  web前端界以一种讲故事方式讲解每一种模式,让每位读者都能读懂。
  书中案例都是实际工作中的真实案例,让读者身临其境。
  全面涵盖专门针对javascript的36个设计模式,帮助读者尽快提高开发效率
  深入剖析面向对象的设计原则及代码重构,帮助读者快速融入团队项目开发中
  本书通过职场主人公“小铭”实战历练,介绍了他从菜鸟到高级程序员的蜕变过程,值得每一个程序员借鉴和学习!
  各种设计模式的原则和准确定义、应用方法实践

 

]

作者简介

[

张容铭百度资深高级web前端研发工程师,长期工作在web前端一线上,现研发与维护百度图片搜索业务,曾主导百度新首页项目改版等。 喜欢钢琴,素描,而又常带着他的单反各地旅行。

]

目录

**篇 面向对象编程第1章 灵活的语言–javascript1.1 入职**天1.2 函数的另一种形式1.3 用对象收编变量1.4 对象的另一种形式1.5 真假对象1.6 类也可以1.7 一个检测类1.8 方法还可以这样用1.9 函数的祖先1.10 可以链式添加吗1.11 换一种方式使用方法下章剧透忆之获我问你答第2章 写的都是看到的–面向对象编程2.1 两种编程风格–面向过程与面向对象2.2 包装明星–封装2.3 传宗接代–继承2.4 老师不止一位–多继承2.5 多种调用方式–多态下章剧透忆之获我问你答 第二篇 创建型设计模式第3章 神奇的魔术师–简单工厂模式3.1 工作中的**次需求3.2 如果类太多,那么提供一个3.3 一个对象有时也可代替许多类3.4 你的理解决定你选择的方式下章剧透忆之获我问你答第4章 给我一张名片–工厂方法模式4.1 广告展现4.2 方案的抉择4.3 安全模式类4.4 安全的工厂方法下章剧透忆之获我问你答第5章 出现的都是幻觉–抽象工厂模式5.1 带头模范–抽象类5.2 幽灵工厂–抽象工厂模式5.3 抽象与实现下章剧透忆之获我问你答第6章 分即是合–建造者模式6.1 发布简历6.2 创建对象的另一种形式6.3 创建一位应聘者下章剧透忆之获我问你答第7章 语言之魂–原型模式7.1 语言中的原型7.2 创建一个焦点图7.3 *优的解决方案7.4 原型的拓展7.5 原型继承下章剧透忆之获我问你答第8章 一个人的寂寞–单例模式8.1 滑动特效8.2 命名空间的管理员8.3 模块分明8.4 创建一个小型代码库8.5 无法修改的静态变量8.6 惰性单例下章剧透忆之获我问你答 第三篇 结构型设计模式第9章 套餐服务–外观模式9.1 添加一个点击事件9.2 兼容方式9.3 除此之外9.4 小型代码库下章剧透忆之获我问你答第10章 水管弯弯–适配器模式10.1 引入jquery10.2 生活中的适配器10.3 jquery适配器10.4 适配异类框架10.5 参数适配器10.6 数据适配10.7 服务器端数据适配下章剧透忆之获我问你答第11章 牛郎织女–代理模式11.1 无法获取图片上传模块数据11.2 一切只因跨域11.3 站长统计11.4 jsonp11.5 代理模板下章剧透忆之获我问你答第12章 房子装修–装饰者模式12.1 为输入框的新需求12.2 装饰已有的功能对象12.3 为输入框添砖加瓦下章剧透忆之获我问你答第13章 城市间的公路–桥接模式13.1 添加事件交互13.2 提取共同点13.3 事件与业务逻辑之间的桥梁13.4 多元化对象下章剧透忆之获我问你答第14章 超值午餐–组合模式14.1 新闻模块十万火急14.2 餐厅里的套餐业务14.3 每个成员要有祖先14.4 组合要有容器类14.5 创建一个新闻类14.6 把新闻模块创建出来14.7 表单中的应用下章剧透忆之获我问你答第15章 城市公交车–享元模式15.1 翻页需求15.2 冗余的结构15.3 享元对象15.4 实现需求15.5 享元动作下章剧透忆之获我问你答 第四篇 行为型设计模式第16章 照猫画虎–模板方法模式16.1 提示框归一化16.2 美味的蛋糕16.3 创建基本提示框16.4 模板的原型方法16.5 根据模板创建类16.6 继承类也可作为模板类16.7 创建一个提示框16.8 创建多类导航16.9 创建导航更容易下章剧透忆之获我问你答第17章 通信卫星–观察者模式17.1 团队开发的坎坷17.2 卫星的故事17.3 创建一个观察者17.4 拉出来溜溜17.5 使用前的思考17.6 大显身手17.7 对象间解耦17.8 课堂演练下章剧透忆之获我问你答第18章 超级玛丽–状态模式18.1 *美图片18.2 分支判断的思考18.3 状态对象的实现18.4 状态对象演练18.5 超级玛丽18.6 状态的优化18.7 两种使用方式下章剧透忆之获我问你答第19章 活诸葛–策略模式19.1 商品促销19.2 活诸葛19.3 策略对象19.4 诸葛奇谋19.5 缓冲函数19.6 表单验证19.7 算法拓展19.8 算法调用下章剧透忆之获我问你答第20章 有序车站–职责链模式20.1″半成品”需求20.2 分解需求20.3 **站–请求模块20.4 下一站–响应数据适配模块20.5 终点站–创建组件模块20.6 站点检测–单元测试20.7 方案确定下章剧透忆之获我问你答第21章 命令模式21.1 自由化创建视图21.2 命令对象21.3 视图创建21.4 视图展示21.5 命令接口21.6 大功告成21.7 绘图命令21.8 写一条命令下章剧透忆之获我问你答第22章 驻华大使–访问者模式22.1 设置样式22.2 自娱自乐的ie22.3 访问操作元素22.4 事件自定义数据22.5 原生对象构造器22.6 对象访问器22.7 操作类数组下章剧透忆之获我问你答第23章 媒婆–中介者模式23.1 导航设置层23.2 创建中介者对象23.3 试试看,可否一用23.4 攻克需求23.5 订阅消息23.6 发布消息下章剧透忆之获我问你答第24章 做好笔录–备忘录模式24.1 新闻展示24.2 缓存数据24.3 新闻缓存器24.4 工作中的备忘录下章剧透忆之获我问你答第25章 点钞机–迭代器模式25.1 简化循环遍历25.2 迭代器25.3 实现迭代器25.4 小试牛刀25.5 数组迭代器25.6 对象迭代器25.7 试用迭代器25.8 同步变量迭代器25.9 分支循环嵌套问题25.10 解决方案下章剧透忆之获我问你答第26章 语言翻译–解释器模式26.1 统计元素路径26.2 描述文法26.3 解释器……第五篇 技巧型设计模式第六篇 架构型设计模式附录a

封面

JavaScript设计模式

书名:JavaScript设计模式

作者:张容铭

页数:316

定价:¥59.0

出版社:人民邮电出版社

出版日期:2015-08-01

ISBN:9787115396860

PDF电子书大小:107MB 高清扫描完整版



本文标题:《JavaScript设计模式》PDF下载

资源仅供学习参考,禁止用于商业用途,请在下载后24小时内删除!