第1章 遵循最佳实践 2
不唐突和渐进增强 2
让JavaScpt运行起来 4
把行为从结构中分离出来 4
不要版本检测 11
通过平稳退化保证可访问性 13
为重用命名空间而进行规划 14
通过可重用的对象把事情简化 17
一定要自己动手写代码 26
JavaScpt语法中常见的陷阱 27
区分大小写 27
单引号与双引号 27
换行 28
可选的分号和花括号 28
重载(并非真正的重载) 29
匿名函数 30
作用域解析和闭包 30
迭代对象 35
函数的调用和引用(不带括号) 36
实例:WYSIWYG JavaScpt翻转图 36
小结 43
第2章 创建可重用的对象 44
对象中包含什么 44
继承 45
理解对象成员 46
window对象中的一切 48
理解作用域和闭包是根本 51
创建你自己的对象 52
一变多:创建构造函数 53
添加静态方法 54
向原型中添加公有方法 55
公有、私有、特权和静态成员真那么重要吗 58
对象字面量 59
this是什么 61
try {}、catch{}和异常处理 66
实例:你自己的调试日志 67
为什么需要JavaScript日志对象 68
myLogger ()对象 68
小结 76
第3章DOM2核心和DOM2 HTML 77
DOM不是JavaScript,它是文档 77
DOM的级别 78
DOM 0级 78
DOM 1级 78
DOM 2级 79
DOM 3级 79
哪个级别适合你 81
创建示例文档 82
创建DOM文件 83
选择一个浏览器 84
DOM核心 86
继承在DOM中的重要性 88
核心Node对象 89
核心Element对象 102
核心Document对象 104
遍历和迭代DOM树 106
DOM HTML 108
DOM2 HTML的HTMLDocument对象 108
DOM2 HTML的HTMLElement对象 109
实例:将手工HTML代码转换为DOM代码 110
DOM生成工具的HTML文件 111
使用示例HTML片段进行测试 112
扩充ADS库 113
generateDOM对象的框架 115
小结 127
第4章 响应用户操作和事件 128
DOM2级事件 129
事件的类型 130
对象事件 130
鼠标移动事件 132
鼠标单击事件 134
键盘事件 136
表单相关的事件 136
针对W3C DOM的事件 142
自定义事件 143
控制事件流和注册事件侦听器 143
事件流 143
注册事件 151
在事件侦听器中访问事件对象 159
跨浏览器的事件属性和方法 160
小结 170
第5章 动态修改样式和层叠样式表 171
W3C DOM2样式规范 171
CSSStyleSheet对象 171
CSSStyleRule对象 172
CSSStyleDeclaration对象 173
支持的匮乏 173
当DOM脚本遇到样式 173
把样式置于DOM脚本之外 179
style属性 179
基于className切换样式 182
切换样式表 185
修改CSS规则 192
访问计算样式 200
Microsoft的fi1ter属性 201
实例:简单的渐变效果 204
小结 207
第6章 案例研究:图像裁剪和缩放工具 208
测试文件 208
imageEditor对象 212
调用imageEditor工具 216
imageEditor载入事件 217
创建编辑器标记和对象 218
向imageEditor对象添加事件侦听器 224
缩放图像 227
裁剪图像 230
未完成的图像编辑器 234
小结 234
第7章 向应用程序中加入Ajax 236
组合的技术 236
语义化XHTML和DOM 237
JavaScript和XMLHttpRequest对象 237
XML 244
一个可重用的对象 248
Ajax是正确的选择吗 253
为什么Ajax会破坏网站及如何解决 253
依赖JavaScript生成内容 253
通过<script>标签绕过跨站点限制 254
后退按钮和书签功能 260
完成请求的赛跑 270
增加资源占用 278
问题解决了吗 278
实例:Ajax增强的相册 278
小结 285
第8章 案例研究:实现带进度条的异步文件上传功能 286
信息载入时的小生命 288
起点 291
完成整合:上传进度指示器 292
addprogressBar对象的结构 294
载入事件 296
addprogressBar()对象 296
小结 308
第9章 通过库来提高生产力 310
选择合适的库 311
增强DOM操作能力 314
连缀语法 314
通过回调函数进行过滤 321
操纵DOM文档 322
处理事件 324
注册事件 325
自定义事件 327
访问和操纵样式 329
通信 329
小结 334
第10章 添加效果增强用户体验 335
自己动手实现效果 335
让我看到内容 336
提供反馈 340
几个视觉效果库简介 342
视觉盛宴 343
MOO式的CSS属性修改 344
通过Script*aculo*us实现视觉效果 353
通过Moo.fx实现逼真的运动效果 356
圆角效果 360
其他库 362
行为增强 362
小结 374
第11章 丰富的Mashup!运用API添加地图、搜索及更多功能 375
API密钥 376
客户端API:离不开JavaScript 377
地图中的Mashup应用 377
Ajax搜索请求 388
地图与搜索的Mashup应用 397
服务器端API:需要代理脚本 400
通过Basecamp构建集成的To-Do列表 403
通过Flickr取得个性头像 412
小结 416
第12章 案例研究:用DOM设计选择列表 417
经典的感觉 417
构建更好的选择列表 418
策略?我们不需要臭哄哄的策略 420
相关的文件 420
FauxSelect对象 421
开始创建人造select元素 423
查找select元素 425
构建DOM元素 427
添加事件——为人造select赋予生命 431
让表单绽放光彩 435
行为修正 445
z-index来救急 447
键盘控制及其他细节 449
select太大了吗 454
最后的细节 455
继续替换select的冒险 456
小结 457