出版时间:2008-7 出版社:人民邮电出版社 作者:Jeffrey Sambells,Aaron Gustafson 页数:457 译者:李松峰,李雅雯
Tag标签:无
内容概要
《图灵程序设计从书:JavaScript DOM高级程序设计》注重理论与实践的结合,全面讲述高级的DOM脚本编程。《图灵程序设计从书:JavaScript DOM高级程序设计》分为3个部分:第一部分“深入理解DOM脚本编程”,涉及W3C DOM规范的各方面,包括非标准的浏览器支持和不支持的内容;第二部分“浏览器外部通信”,以Ajax和客户端—服务器端通信为主题;第三部分“部分高级脚本编程资源”,集中介绍了一批第三方脚本编程资源,包括库和API。同时,每部分的最后一章都为案例研究,将学到的内容应用于实践。通过学习全书内容,读者将能构建起属于自己的DOM实用方法库。
作者简介
Jeffrey Sambells,资深Web设计师和程序员,We-Create公司创始人之一暨研发总监。除本书外,他还与人合写了Beginning Google Maps Applications with PHP and Ajax等著作。 Aaron Gustafson,世界顶尖的Web工程师,创建了Web咨询公司Easy!Designs LLC.。Aaron是WaSP(Web标准项目)和GAWDS(可访问性Web设计协会)的成员。他还是A List Apart网站的技术编辑,Digital Web Magazine和MSDN等著名杂志的撰稿人。
书籍目录
第一部分 深入理解DOM脚本编程第1章 遵循最佳实践1.1 不唐突和渐进增强1.2 让JavaScript运行起来1.2.1 把行为从结构中分离出来1.2.2 不要版本检测1.2.3 通过平稳退化保证可访问性1.2.4 为重用命名空间而进行规划1.2.5 通过可重用的对象把事情简化1.2.6 一定要自己动手写代码1.3 JavaScript语法中常见的陷阱1.3.1 区分大小写1.3.2 单引号与双引号1.3.3 换行1.3.4 可选的分号和花括号1.3.5 重载(并非真正的重载)1.3.6 匿名函数1.3.7 作用域解析和闭包1.3.8 迭代对象1.3.9 函数的调用和引用(不带括号)1.4 实例:WYSIWYGJavaScript翻转图1.5 小结第2章 创建可重用的对象2.1 对象中包含什么2.1.1 继承2.1.2 理解对象成员2.1.3 window对象中的一切2.1.4 理解作用域和闭包是根本2.2 创建你自己的对象2.2.1 一变多:创建构造函数2.2.2 添加静态方法2.2.3 向原型中添加公有方法2.2.4 公有、私有、特权和静态成员真那么重要吗2.2.5 对象字面量2.3 this是什么2.4 try{}、catch{}和异常处理2.5 实例:你自己的调试日志2.5.1 为什么需要JavaScript日志对象2.5.2 myLogger()对象2.6 小结第3章 DOM2核心和DOM2 HTML3.1 DOM不是JavaScript,它是文档3.2 DOM的级别3.2.1 DOM 0 级3.2.2 DOM 1 级3.2.3 DOM 2 级3.2.4 DOM 3 级3.2.5 哪个级别适合你3.3 创建示例文档3.3.1 创建DOM文件3.3.2 选择一个浏览器3.4 DOM核心3.4.1 继承在DOM中的重要性3.4.2 核心Node对象3.4.3 核心Element对象3.4.4 核心Document对象3.4.5 遍历和迭代DOM树3.5 DOM HTML3.5.1 DOM2 HTML 的HTMLDocument对象3.5.2 DOM2 HTML 的HTMLElement对象3.6 实例:将手工HTML代码转换为DOM代码3.6.1 DOM生成工具的HTML文件3.6.2 使用示例HTML片段进行测试3.6.3 扩充ADS库3.6.4 generateDOM对象的框架3.7 小结第4章 响应用户操作和事件4.1 DOM2级事件4.2 事件的类型4.2.1 对象事件4.2.2 鼠标移动事件4.2.3 鼠标单击事件4.2.4 键盘事件4.2.5 表单相关的事件4.2.6 针对W3C DOM的事件4.2.7 自定义事件4.3 控制事件流和注册事件侦听器4.3.1 事件流4.3.2 注册事件4.3.3 在事件侦听器中访问事件对象4.3.4 跨浏览器的事件属性和方法4.4 小结第5章 动态修改样式和层叠样式表5.1 W3CDOM2样式规范5.1.1 CSSStyleSheet对象5.1.2 CSSStyleRule对象5.1.3 CSSStyleDeclaration对象5.1.4 支持的匮乏5.2 当DOM 脚本遇到样式5.3 把样式置于DOM脚本之外5.3.1 style属性5.3.2 基于className切换样式5.3.3 切换样式表5.3.4 修改CSS规则5.4 访问计算样式5.5 Microsoft的filter属性5.6 实例:简单的渐变效果5.7 小结第6章 案例研究:图像裁剪和缩放工具6.1 测试文件6.2 imageEditor对象6.2.1 调用imageEditor工具6.2.2 imageEditor载入事件6.2.3 创建编辑器标记和对象6.2.4 向imageEditor对象添加事件侦听器6.2.5 缩放图像6.2.6 裁剪图像6.2.7 未完成的图像编辑器6.3 小结第二部分 浏览器外部通信第7章 向应用程序中加入Ajax7.1 组合的技术7.1.1 语义化XHTML和DOM7.1.2 JavaScript和XMLHttpRequest对象7.1.3 XML7.1.4 一个可重用的对象7.1.5 Ajax是正确的选择吗7.2 为什么Ajax会破坏网站及如何解决7.2.1 依赖JavaScript生成内容7.2.2 通过script标签绕过跨站点限制7.2.3 后退按钮和书签功能7.2.4 完成请求的赛跑7.2.5 增加资源占用7.2.6 问题解决了吗7.3 实例:Ajax增强的相册7.4 小结第8章 案例研究:实现带进度条的异步文件上传功能8.1 信息载入时的小生命8.2 起点8.3 完成整合:上传进度指示器8.3.1 addProgressBar()对象的结构8.3.2 载入事件8.3.3 addProgressBar()对象8.4 小结第三部分 部分高级脚本编程资源第9章 通过库来提高生产力9.1 选择合适的库9.2 增强DOM操作能力9.2.1 连缀语法9.2.2 通过回调函数进行过滤9.2.3 操纵DOM文档9.3 处理事件9.3.1 注册事件9.3.2 自定义事件9.4 访问和操纵样式9.5 通信9.6 小结第10章 添加效果增强用户体验10.1 自己动手实现效果10.1.1 让我看到内容10.1.2 提供反馈10.2 几个视觉效果库简介10.3 视觉盛宴10.3.1 MOO式的CSS属性修改10.3.2 通过Script.aculo.us实现视觉效果10.3.3 通过Moo.fx实现逼真的运动效果10.3.4 圆角效果10.3.5 其他库10.4 行为增强10.5 小结第11章 丰富的Mashup!运用API添加地图、搜索及更多功能11.1 API密钥11.2 客户端API:离不开JavaScript11.2.1 地图中的Mashup应用11.2.2 Ajax搜索请求11.2.3 地图与搜索的Mashup应用11.3 服务器端API:需要代理脚本11.3.1 通过Basecamp构建集成的To-Do列表11.3.2 通过Flickr取得个性头像11.4 小结第12章 案例研究:用DOM设计选择列表12.1 经典的感觉12.2 构建更好的选择列表12.3 策略?我们不需要臭哄哄的策略12.3.1 相关的文件12.3.2 FauxSelect对象12.3.3 开始创建人造select元素12.3.4 查找select元素12.3.5 构建DOM元素12.4 添加事件——为人造select赋予生命12.5 让表单绽放光彩12.6 行为修正12.6.1 z-index来救急12.6.2 键盘控制及其他细节12.6.3 select太大了吗12.7 最后的细节12.8 继续替换select的冒险12.9 小结
章节摘录
第一章 遵循最佳实践 你很兴奋,你的客户也很兴奋。你刚刚为客户安装启用了新版的网站,一切都很顺利。网站很花哨,它历经了数小时汗水和泪水的浇灌,每一处设计细节——扩展式菜单、交互的Aiax都精心调试过,所有新式花样无所不包。它看上去很不错,运行得也很完美,所有人都沉浸在喜悦中。然而,一周之后,噩梦开始了。客户慌里慌张地打来电话,好像是据他们的部分顾客来电话反应说主页上的链接打不开了,而另外一些顾客在填写反馈表单时也碰到了问题。但在你和你的客户那里却不存在这些的问题。还有一些人也打来电话,抱怨下载网站的每一个页面都要等很长时间,即使看上去网页内容并不很多,而你从来没有发现下载时间有问题。更糟糕的是,随后,你客户发现网站在搜索引擎中的排名一落千丈。看来事情没有想象的那么乐观,但问题出在哪里 呢?下面我们就一起来查找原因。 最佳实践是人们做事时应该遵循的、被公认和经过验证的模式。虽然不一定是唯一的,甚至不是最佳的方式,但这些方式是大多数人认同的做事方式。一般的书在最后部分会提到一些最佳实践,这更多地是一种提示,即在你已学会了每件事并按自己的方式行事时,告诉你还会有一种最适当的方式。我之所以把最佳实践放在前面来讲,就是为了让你在开始学习新知识之前,先明确正确的方向。如果有阳关大道,那又何必去走独木桥呢? 1.1 不唐突和渐进增强 XHTML(ExteIlsibleHyperext Markup Laneuaee,可扩展超文本标记语言)、CSS(Cascading StyleSheet,层叠样式表)和使用JaVaScript的DOM(DocumentObjectModel,文档对象模型)脚本是Web设计的三个主要部分。其中,XHTML用于提供文档结构的语义标记,CSS为文档布局提供定位和样式,而DOM脚本编程用于增强文档的行为和交互性。发现了吗?我刚才说DOM脚本“增强”,而不是为文档“提供”行为和交互性。“增强”和“提供”之间的差异暗示了一个重要区别。我们都学过XHTML语义,知道验证文档是否符合w3c规范,而且也都在用CSS来为严格型XHTML文档标记应用适当的样式(对吧?)。但是,作为第三个主要部分的DOM脚本,虽然它可以把事情做得格外漂亮,为我们的wleb应用程序增光添彩,却有可能是一个唐突的家伙。DOM脚本编程依赖于JavaScript。
编辑推荐
“本书是一本全景式的、沟通历史和未来的Web开发经典好书。是对现有JavaScript DoM程序开发最佳实践的一次大检阅和大放送,是推动Web标准化和向下一代Web开发挺进的里程碑式著作。” ——本书译者 “如果你是一位中级JavaScript人员,还想更上一层楼,那么这将是使你梦想成真的绝妙好书。” ——DOMAssistant库的作者Robert Nyman 本书深入浅出地讲述了作为一名专业的Web开发人员(或者真正的高手)所必须了解和掌握的高级知识,是Web编程领域名副其实的扛鼎之作。书中对核心JavaScript原理的总结和概括、对最佳实践的倡导和践行、对DOM规范讲解的提纲挈领、对浏览器外部通信(Ajax)的反思与解决之道、对Web 2.o rXJ容整合(Mashup)的分类与讲说等,无一不折射出这本书是作者博观约取、厚积薄发的心血力作。 与此同时,如果你也醉心于Prototype、jQuery、YUI、Ext等优秀的JavaScript库,想见微知著地真正理解这些库背后的工作原理,甚至希望创建自己的库,那么这本书恰好适合你。
图书封面
图书标签Tags
无
评论、评分、阅读与下载