前 言
第一部分 准备篇
第 1 章 准备开发环境••••••••••••••••••••••••••2
1.1 安装 JDK ••••••••••••••••••••••••••••••••••••••••••••2
1.2 安装 Eclipse••••••••••••••••••••••••••••••••••••••••2
1.3 安装 GWT 1.7 的 Eclipse 插件 ••••••••••3
1.4 安装 GWT 2.0 的 SDK 以及
Eclipse 插件••••••••••••••••••••••••••••••••••••••••4
1.5 辅助工具 ••••••••••••••••••••••••••••••••••••••••••••5
1.5.1 Internet Explorer Developer
Toolbar •••••••••••••••••••••••••••••••••••••••••5
1.5.2 Firebug•••••••••••••••••••••••••••••••••••••••••6
1.6 小结••••••••••••••••••••••••••••••••••••••••••••••••••••7
第 2 章 Hello GWT•••••••••••••••••••••••••••••••8
2.1 在 Eclipse 中创建项目•••••••••••••••••••••••8
2.2 运行调试项目 ••••••••••••••••••••••••••••••••••10
2.3 JUnit 测试•••••••••••••••••••••••••••••••••••••••••14
2.4 发布网站 ••••••••••••••••••••••••••••••••••••••••••16
2.5 ANT 发布•••••••••••••••••••••••••••••••••••••••••16
2.6 小结••••••••••••••••••••••••••••••••••••••••••••••••••17
第二部分 基础篇
第 3 章 GWT 模块 ••••••••••••••••••••••••••••••20
3.1 GWT 模块详解 ••••••••••••••••••••••••••••••••20
3.2 模块入口点•••••••••••••••••••••••••••••••••••••• 22
3.3 模块继承•••••••••••••••••••••••••••••••••••••••••• 22
3.4 附加 CSS 和 JavaScript•••••••••••••••••••• 23
3.5 路径配置•••••••••••••••••••••••••••••••••••••••••• 25
3.6 延迟绑定•••••••••••••••••••••••••••••••••••••••••• 29
3.7 发布 JAR•••••••••••••••••••••••••••••••••••••••••• 33
3.8 深入研究•••••••••••••••••••••••••••••••••••••••••• 34
3.9 小结 ••••••••••••••••••••••••••••••••••••••••••••••••• 37
第 4 章 JSNI ••••••••••••••••••••••••••••••••••••••••• 38
4.1 JSNI 和 JavaScript ••••••••••••••••••••••••••• 38
4.2 类型映射•••••••••••••••••••••••••••••••••••••••••• 39
4.3 JavaScriptObject••••••••••••••••••••••••••••••• 40
4.4 JsArray ••••••••••••••••••••••••••••••••••••••••••••• 42
4.5 JSNI 中的特殊变量••••••••••••••••••••••••• 42
4.6 在 JSNI 中访问 GWT 函数••••••••••••• 46
4.7 异常处理•••••••••••••••••••••••••••••••••••••••••• 49
4.8 外部 JavaScript 访问 GWT函数•••••••• 50
4.9 整合 jQuery•••••••••••••••••••••••••••••••••••••• 51
4.10 在 GWT 中使用正则
表达式 ••••••••••••••••••••••••••••••••••••••••••• 57
4.11 小结•••••••••••••••••••••••••••••••••••••••••••••••• 60
第 5 章 在 GWT 中使用 XML •••••••• 61
5.1 XML 简介•••••••••••••••••••••••••••••••••••••••• 61
5.2 XML 操作•••••••••••••••••••••••••••••••••••••••• 62
5.2.1 XML 文档••••••••••••••••••••••••••••••••• 62
5.2.2 XML 节点 •••••••••••••••••••••••••••••••••64
5.2.3 XML 元素节点••••••••••••••••••••••••••67
5.2.4 XML 文本节点••••••••••••••••••••••••••68
5.3 在 GWT 中使用 XPath•••••••••••••••••••••68
5.4 小结••••••••••••••••••••••••••••••••••••••••••••••••••76
第 6 章 GWT 控件详解•••••••••••••••••••••77
6.1 界面对象 ••••••••••••••••••••••••••••••••••••••••••77
6.2 Widget•••••••••••••••••••••••••••••••••••••••••••••••82
6.3 面板••••••••••••••••••••••••••••••••••••••••••••••••••83
6.4 控件生命周期 ••••••••••••••••••••••••••••••••••85
6.5 控件事件管理 ••••••••••••••••••••••••••••••••••87
6.5.1 注册控件事件处理句柄••••••••••••87
6.5.2 阻止控件默认行为••••••••••••••••••••88
6.5.3 阻止事件冒泡 •••••••••••••••••••••••••••89
6.5.4 onBrowserEvent•••••••••••••••••••••••••90
6.6 GWT 全局类 ••••••••••••••••••••••••••••••••••••91
6.6.1 DOM 类•••••••••••••••••••••••••••••••••••••91
6.6.2 GWT 类•••••••••••••••••••••••••••••••••••••92
6.6.3 Window 类•••••••••••••••••••••••••••••••••94
6.7 小结••••••••••••••••••••••••••••••••••••••••••••••••••97
第 7 章 使用 GWT 控件••••••••••••••••••••98
7.1 简单控件 ••••••••••••••••••••••••••••••••••••••••••98
7.1.1 包装已有控件 •••••••••••••••••••••••••••98
7.1.2 图片超链接 •••••••••••••••••••••••••••••••99
7.1.3 图片按钮•••••••••••••••••••••••••••••••••••99
7.1.4 复选框•••••••••••••••••••••••••••••••••••••••99
7.1.5 单选框•••••••••••••••••••••••••••••••••••••100
7.1.6 文件上传•••••••••••••••••••••••••••••••••101
7.1.7 DatePicker••••••••••••••••••••••••••••••••103
7.2 列表和菜单 ••••••••••••••••••••••••••••••••••••104
7.2.1 列表•••••••••••••••••••••••••••••••••••••••••104
7.2.2 带建议的输入框••••••••••••••••••••••105
7.2.3 树•••••••••••••••••••••••••••••••••••••••••••••105
7.2.4 菜单 •••••••••••••••••••••••••••••••••••••••• 107
7.3 面板 ••••••••••••••••••••••••••••••••••••••••••••••• 108
7.3.1 装饰面板••••••••••••••••••••••••••••••••• 108
7.3.2 流式布局面板••••••••••••••••••••••••• 108
7.3.3 水平布局面板和垂直布局
面板••••••••••••••••••••••••••••••••••••••••• 109
7.3.4 绝对布局面板••••••••••••••••••••••••• 109
7.3.5 Tab 面板•••••••••••••••••••••••••••••••••• 109
7.3.6 滚动面板••••••••••••••••••••••••••••••••• 110
7.4 表格 ••••••••••••••••••••••••••••••••••••••••••••••• 111
7.4.1 简单表格••••••••••••••••••••••••••••••••• 111
7.4.2 复杂表格••••••••••••••••••••••••••••••••• 111
7.5 使用与自定义 GWT 控件••••••••••••• 112
7.5.1 ComboInput 控件结构•••••••••••• 112
7.5.2 DataItem•••••••••••••••••••••••••••••••••• 113
7.5.3 ListBox•••••••••••••••••••••••••••••••••••• 114
7.5.4 Selected 事件 •••••••••••••••••••••••••• 117
7.5.5 TriggerInput••••••••••••••••••••••••••••• 120
7.5.6 ComboBox•••••••••••••••••••••••••••••• 122
7.6 小结 ••••••••••••••••••••••••••••••••••••••••••••••• 125
第 8 章 GWT-RPC ••••••••••••••••••••••••••• 126
8.1 GWT 中的XMLHTTPRequest••••••••• 126
8.1.1 HTTPRequestImpl••••••••••••••••••• 126
8.1.2 RequestBuilder •••••••••••••••••••••••• 127
8.1.3 请求动态数据••••••••••••••••••••••••• 129
8.1.4 XML•••••••••••••••••••••••••••••••••••••••• 132
8.2 JSON•••••••••••••••••••••••••••••••••••••••••••••• 134
8.2.1 JSONValue•••••••••••••••••••••••••••••• 134
8.2.2 JSONValue 的派生类 ••••••••••••• 135
8.2.3 完整的 JSON 例子 ••••••••••••••••• 136
8.3 GWT-RPC •••••••••••••••••••••••••••••••••••••• 138
8.3.1 RPC 远程接口 •••••••••••••••••••••••• 138
8.3.2 服务器实现••••••••••••••••••••••••••••• 139
8.3.3 异步接口文件••••••••••••••••••••••••• 140
8.3.4 在程序中使用GWT-RPC •••••••••140
8.3.5 整合 Hibernate•••••••••••••••••••••••••141
8.4 小结••••••••••••••••••••••••••••••••••••••••••••••••145
第 9 章 Ext GWT•••••••••••••••••••••••••••••••146
9.1 Ext GWT 简介及安装••••••••••••••••••••146
9.2 Window•••••••••••••••••••••••••••••••••••••••••••148
9.2.1 窗口布局•••••••••••••••••••••••••••••••••149
9.2.2 Viewport ••••••••••••••••••••••••••••••••••151
9.2.3 Dialog ••••••••••••••••••••••••••••••••••••••152
9.2.4 窗口的显示与关闭••••••••••••••••••153
9.3 数据管理 ••••••••••••••••••••••••••••••••••••••••154
9.4 Grid•••••••••••••••••••••••••••••••••••••••••••••••••157
9.5 树控件••••••••••••••••••••••••••••••••••••••••••••159
9.5.1 图标显示•••••••••••••••••••••••••••••••••160
9.5.2 节点选择事件 •••••••••••••••••••••••••160
9.6 皮肤••••••••••••••••••••••••••••••••••••••••••••••••161
9.7 小结••••••••••••••••••••••••••••••••••••••••••••••••162
第三部分 实战篇
第 10 章 俄罗斯方块游戏 ••••••••••••••164
10.1 游戏设计 ••••••••••••••••••••••••••••••••••••••164
10.1.1 游戏简介 •••••••••••••••••••••••••••••••164
10.1.2 游戏规则 •••••••••••••••••••••••••••••••165
10.1.3 设计思路 •••••••••••••••••••••••••••••••166
10.2 编码实现 ••••••••••••••••••••••••••••••••••••••167
10.2.1 游戏场地 •••••••••••••••••••••••••••••••167
10.2.2 方块•••••••••••••••••••••••••••••••••••••••170
10.2.3 游戏控制器 •••••••••••••••••••••••••••177
10.3 界面实现及操作完善•••••••••••••••••••187
10.3.1 候选面板•••••••••••••••••••••••••••••••••187
10.3.2 计分与等级 •••••••••••••••••••••••••••189
10.3.3 增加操作便利性••••••••••••••••••••191
10.3.4 界面美化 •••••••••••••••••••••••••••••••192
10.4 联机对战•••••••••••••••••••••••••••••••••••••• 193
10.4.1 原理 •••••••••••••••••••••••••••••••••••••• 193
10.4.2 等待游戏开始••••••••••••••••••••••• 194
10.4.3 交换数据••••••••••••••••••••••••••••••• 198
10.4.4 胜负判定••••••••••••••••••••••••••••••• 204
10.4.5 障碍行••••••••••••••••••••••••••••••••••• 206
10.5 小结•••••••••••••••••••••••••••••••••••••••••••••• 209
第 11 章 费用申请审批流程 ••••••••• 210
11.1 流程设计•••••••••••••••••••••••••••••••••••••• 210
11.1.1 流程简介••••••••••••••••••••••••••••••• 210
11.1.2 工作流引擎••••••••••••••••••••••••••• 210
11.1.3 表单••••••••••••••••••••••••••••••••••••••• 211
11.2 工作流引擎实现 •••••••••••••••••••••••••• 211
11.2.1 环境配置••••••••••••••••••••••••••••••• 211
11.2.2 业务规则定义••••••••••••••••••••••• 214
11.2.3 jBPM 数据库初始化••••••••••••• 218
11.3 表单实现•••••••••••••••••••••••••••••••••••••• 220
11.3.1 HTML 面板••••••••••••••••••••••••••• 220
11.3.2 表单对话框••••••••••••••••••••••••••• 225
11.3.3 权限控制••••••••••••••••••••••••••••••• 228
11.3.4 类型校验••••••••••••••••••••••••••••••• 232
11.4 审批流程的界面实现 •••••••••••••••••• 233
11.4.1 AsyncCallbackEx •••••••••••••••••• 233
11.4.2 Outlook 面板••••••••••••••••••••••••• 234
11.4.3 工作列表••••••••••••••••••••••••••••••• 236
11.4.4 整体布局••••••••••••••••••••••••••••••• 241
11.4.5 用户登录••••••••••••••••••••••••••••••• 244
11.4.6 全局事件管理••••••••••••••••••••••• 247
11.4.7 遮蔽效果••••••••••••••••••••••••••••••• 249
11.4.8 实现 BizzAction•••••••••••••••••••• 250
11.5 业务流转•••••••••••••••••••••••••••••••••••••• 254
11.5.1 申请表••••••••••••••••••••••••••••••••••• 254
11.5.2 审批表••••••••••••••••••••••••••••••••••• 257
11.6 小结•••••••••••••••••••••••••••••••••••••••••••••• 261
第四部分 高级篇
第 12 章 GWT 与 Flex 整合•••••••••••264
12.1 Flex 的优势 ••••••••••••••••••••••••••••••••••264
12.2 查看流程图的 Flex•••••••••••••••••••••••265
12.3 加入网页 ••••••••••••••••••••••••••••••••••••••275
12.4 与 Flex 交互 •••••••••••••••••••••••••••••••••278
12.5 小结••••••••••••••••••••••••••••••••••••••••••••••283
第 13 章 图片缓存 ••••••••••••••••••••••••••••284
13.1 CSS Sprite 简介••••••••••••••••••••••••••••284
13.2 GWT 的实现 ••••••••••••••••••••••••••••••••286
13.3 后端生成了什么•••••••••••••••••••••••••••288
13.4 小结••••••••••••••••••••••••••••••••••••••••••••••288
第 14 章 本地化 •••••••••••••••••••••••••••••••••290
14.1 GWT 如何识别你的语言•••••••••••••290
14.2 本地化配置 ••••••••••••••••••••••••••••••••••291
14.3 日期格式化 ••••••••••••••••••••••••••••••••••294
14.4 字符串动态本地化 •••••••••••••••••••••• 295
14.5 小结•••••••••••••••••••••••••••••••••••••••••••••• 296
第 15 章 其他高级功能••••••••••••••••••• 297
15.1 动画•••••••••••••••••••••••••••••••••••••••••••••• 297
15.2 历史管理•••••••••••••••••••••••••••••••••••••• 299
15.3 延时执行•••••••••••••••••••••••••••••••••••••• 301
15.4 等待执行和分片执行 •••••••••••••••••• 301
15.5 代码分割•••••••••••••••••••••••••••••••••••••• 302
15.5.1 SOYC•••••••••••••••••••••••••••••••••••• 304
15.5.2 初始化序列••••••••••••••••••••••••••• 305
15.5.3 编程模式••••••••••••••••••••••••••••••• 306
15.5.4 预加载••••••••••••••••••••••••••••••••••• 307
15.6 UiBinder••••••••••••••••••••••••••••••••••••••• 308
15.6.1 HTML 绑定 •••••••••••••••••••••••••• 308
15.6.2 控件绑定••••••••••••••••••••••••••••••• 310
15.6.3 CSS 绑定••••••••••••••••••••••••••••••• 311
15.6.4 事件管理••••••••••••••••••••••••••••••• 313
15.6.5 资源打包••••••••••••••••••••••••••••••• 314
15.6.6 创建控件••••••••••••••••••••••••••••••• 316
15.7 小结•••••••••••••••••••••••••••••••••••••••••••••• 316
· · · · · · (
收起)