第1篇 入门篇 2
第1章 了解PHP 2
1.1 什么是PHP 3
1.2 PHP语言的优势 3
1.3 PHP版本 4
1.4 如何学好PHP 5
1.5 准备PHP的开发条件 6
1.5.1 下载PHP及相关软件 6
1.5.2 代码编辑工具 7
1.5.3 下载PHP用户手册 8
1.6 本章小结 9
第2章 PHP开发环境搭建 10
2.1 AppServ——Windows版PHP集成安装包 11
2.1.1 在Windows下搭建PHP开发环境 11
2.1.2 测试AppServ是否安装成功 13
2.2 XAMPP——Linux版PHP集成安装包 14
2.2.1 在Linux下搭建PHP开发环境 14
2.2.2 在Linux下启动、停止XAMPP 15
2.2.3 设置MySQL数据库root用户的密码 16
2.2.4 在Linux下编写第一个PHP程序 16
2.3 PHP开发环境的关键配置 17
2.3.1 Apache服务器的基本配置 17
2.3.2 php.ini文件的基本配置 18
2.4 Dreamweaver开发工具简介 19
2.4.1 Dreamweaver中编码格式的选择 19
2.4.2 Dreamweaver创建站点 20
2.4.3 Dreamweaver创建表格 22
2.4.4 Dreamweaver创建表单 24
2.5 综合应用 26
2.5.1 编写第一个PHP程序 26
2.5.2 输出一张漂亮的图片 27
2.6 本章常见错误 28
2.6.1 AppServ不能安装 28
2.6.2 Apache服务器端口冲突 28
2.7 本章小结 28
2.8 跟我上机 28
第3章 PHP开发基础 29
3.1 PHP工作原理 30
3.2 PHP语法基础 30
3.2.1 PHP标记符 30
3.2.2 PHP的注释 32
3.3 PHP的数据类型 33
3.3.1 标量数据类型 33
3.3.2 复合数据类型 37
3.3.3 特殊数据类型 38
3.3.4 转换数据类型 39
3.3.5 检测数据类型 40
3.4 PHP常量 41
3.4.1 定义和使用常量 41
3.4.2 预定义常量 42
3.5 PHP变量 43
3.5.1 什么是变量 44
3.5.2 定义和使用变量 44
3.5.3 变量的作用域 45
3.5.4 可变变量 47
3.6 PHP运算符 48
3.6.1 算术运算符 48
3.6.2 字符串运算符 49
3.6.3 赋值运算符 49
3.6.4 位运算符 50
3.6.5 递增或递减运算符 50
3.6.6 逻辑运算符 51
3.6.7 比较运算符 52
3.6.8 三元运算符 54
3.6.9 运算符的使用规则 54
3.7 PHP表达式 55
3.8 综合应用 55
3.8.1 输出姚明个人信息 55
3.8.2 计算长方形的面积 56
3.9 本章常见错误 57
3.9.1 定界符的结束标识符之前有空格 57
3.9.2 表达式末尾未写分号 57
3.10 本章小结 57
3.11 跟我上机 57
第4章 PHP流程控制语句 58
4.1 程序的3种结构 59
4.1.1 顺序结构 59
4.1.2 选择结构 59
4.1.3 循环结构 59
4.2 条件控制语句 60
4.2.1 if条件控制语句 60
4.2.2 switch多分支语句 62
4.3 循环控制语句 64
4.3.1 while循环语句 64
4.3.2 do…while循环语句 65
4.3.3 for循环语句 66
4.3.4 foreach循环语句 67
4.4 跳转语句 69
4.4.1 break跳转语句 69
4.4.2 continue跳转语句 71
4.5 综合应用 72
4.5.1 利用continue语句计算100以内奇数的和 72
4.5.2 应用switch语句设计网站主页 73
4.6 本章常见错误 74
4.6.1 条件语句中缺少小括号 74
4.6.2 应用break语句跳出的循环次数不正确 75
4.7 本章小结 75
4.8 跟我上机 75
第5章 函数 76
5.1 自定义函数 77
5.1.1 函数的命名规则 77
5.1.2 自定义函数格式 77
5.1.3 自定义函数的调用 78
5.1.4 函数的参数 78
5.1.5 函数的返回值 80
5.1.6 函数的嵌套调用 81
5.1.7 函数的递归调用 81
5.2 内建函数 82
5.3 输出语句 82
5.3.1 应用print语句输出字符 82
5.3.2 应用echo语句输出字符 84
5.3.3 应用printf语句格式化输出字符 85
5.3.4 应用sprintf语句格式化输出字符 86
5.4 引用文件 87
5.4.1 应用include语句引用文件 87
5.4.2 应用require语句引用文件 88
5.4.3 应用include_once语句引用文件 89
5.4.4 应用require_once语句引用文件 90
5.4.5 include语句和require语句的使用区别 91
5.4.6 include_once语句和require_once语句的使用区别 91
5.5 综合应用 91
5.5.1 自定义一个为数字取绝对值的函数 91
5.5.2 应用include语句构建在线音乐网站主页 92
5.6 本章常见错误 93
5.6.1 使用PHP保留关键字作为函数名 93
5.6.2 自定义函数后没有调用 94
5.6.3 echo语句结束处未写分号 94
5.7 本章小结 94
5.8 跟我上机 94
第6章 字符串操作 95
6.1 字符串简介 96
6.2 单引号与双引号 96
6.3 转义、还原字符串 97
6.3.1 手动转义、还原字符串 97
6.3.2 自动转义、还原字符串 98
6.4 获取字符串长度 100
6.5 截取字符串 102
6.6 比较字符串 103
6.6.1 按字节比较 103
6.6.2 按自然排序法比较 104
6.6.3 指定从源字符串的位置比较 105
6.7 检索字符串 106
6.7.1 strstr()函数 106
6.7.2 substr_count()函数 107
6.8 替换字符串 107
6.8.1 str_ireplace()函数 107
6.8.2 substr replace()函数 109
6.9 去掉字符串首尾空格和特殊字符 110
6.9.1 ltrim()函数 110
6.9.2 rtrim()函数 111
6.9.3 trim()函数 111
6.10 格式化字符串 112
6.11 分割、合成字符串 113
6.11.1 explode()函数 113
6.11.2 implode()函数 114
6.12 字符串与HTML转换 115
6.13 综合应用 116
6.13.1 用substr()函数截取中文字符串 116
6.13.2 对关键字进行高亮显示 117
6.14 本章常见错误 118
6.14.1 截取含有中文的字符串时出现乱码 118
6.14.2 特殊字符插入数据库时未转义 118
6.14.3 explode()函数的分割符为空字符串 118
6.15 本章小结 118
6.16 跟我上机 119
第7章 正则表达式 120
7.1 什么是正则表达式 121
7.2 正则表达式的语法规则 122
7.2.1 行定位符(∧和$) 122
7.2.2 单词定界符(\b、\B) 122
7.2.3 字符类([]) 123
7.2.4 选择字符(|) 123
7.2.5 连字符(-) 124
7.2.6 排除字符([∧]) 124
7.2.7 限定符(?+{n,m}) 124
7.2.8 点号字符(.) 125
7.2.9 转义字符(\) 125
7.2.10 反斜线(\) 126
7.2.11 括号字符(()) 127
7.2.12 整合实用的正则表达式 127
7.3 PCRE兼容正则表达式函数 129
7.3.1 查找字符串 129
7.3.2 替换字符串 130
7.4 综合应用 131
7.4.1 通过JavaScript脚本和正则表达式验证用户注册信息 131
7.4.2 通过正则表达式函数preg_match()验证注册信息 134
7.5 本章常见错误 136
7.5.1 定义正则表达式时未使用定界符“/” 136
7.5.2 匹配特殊字符时未使用转义字符(\) 136
7.6 本章小结 136
7.7 跟我上机 136
第8章 PHP数组 138
8.1 数组概述 139
8.2 数组类型 139
8.2.1 数字索引数组 139
8.2.2 关联数组 139
8.3 声明数组 140
8.3.1 数组命名规则 140
8.3.2 用户创建数组 140
8.3.3 应用函数创建数组 141
8.3.4 创建二维数组 142
8.4 遍历与输出数组 143
8.4.1 遍历数组 143
8.4.2 输出数组元素 146
8.5 PHP的数组函数 146
8.5.1 合并数组 146
8.5.2 统计数组元素个数 147
8.5.3 添加数组元素 147
8.5.4 获取最后一个元素 148
8.5.5 删除重复元素 148
8.5.6 获取指定元素的键名 149
8.5.7 字符串与数组的转换 150
8.5.8 数组排序 150
8.6 PHP全局数组 153
8.6.1 $_SERVER[]全局数组 154
8.6.2 $_GET[]和$_POST[]全局数组 155
8.6.3 $COOKIE[]全局数组 155
8.6.4 $ENV[]全局数组 155
8.6.5 $_REQUEST[]全局数组 155
8.6.6 $_SESSION[]全局数组 155
8.6.7 $FILES[]全局数组 156
8.7 综合应用 156
8.7.1 生成在线考试题 156
8.7.2 向投票系统添加投票选项 157
8.8 本章常见错误 158
8.8.1 数组元素之间用分号进行分隔 158
8.8.2 数组名和已存在的变量重名 158
8.9 本章小结 158
8.10 跟我上机 159
第9章 PHP与Web页面交互 160
9.1 表单概述 161
9.1.1 创建表单 161
9.1.2 认识表单元素 162
9.1.3 定义表单数据提交方法 167
9.2 在Web页中嵌入PHP脚本 169
9.2.1 在HTML标记中嵌入PHP脚本 169
9.2.2 为表单元素赋值 170
9.3 应用PHP全局变量获取表单数据 170
9.3.1 $POST[]全局变量 171
9.3.2 $_GET[]全局变量 172
9.3.3 $_SESSION[]全局变量 173
9.4 对URL传递的参数进行编/解码 173
9.4.1 对URL传递的参数进行编码 173
9.4.2 对URL编码的字符串进行解码 174
9.5 综合应用 175
9.5.1 发布和查看公告信息 175
9.5.2 获取用户的个人信息 177
9.6 本章常见错误 179
9.6.1 全局变量中的表单元素名称与创建表单元素时设置的名称不一致 179
9.6.2 在表单中添加复选框和列表时命名不正确 180
9.7 本章小结 180
9.8 跟我上机 180
第10章 日期和时间 182
10.1 PHP的时区设置 183
10.1.1 在配置文件php.ini中设置时区 183
10.1.2 通过date_default_timezone_set()函数设置时区 183
10.2 UNIX时间戳 184
10.2.1 获取任意日期、时间的时间戳 184
10.2.2 获取当前时间的时间戳 185
10.2.3 将英文文本的日期时间转换为UNIX时间戳 185
10.3 日期和时间的处理 186
10.3.1 对日期和时间进行格式化 187
10.3.2 获取日期和时间信息 189
10.3.3 获取本地化的日期和时间 190
10.3.4 检验日期和时间的有效性 192
10.4 综合应用 193
10.4.1 倒计时 193
10.4.2 计算程序的运行时间 194
10.4.3 网页闹钟 195
10.5 本章常见错误 195
10.5.1 通过strftime()函数对本地时间格式化输出时出现乱码 195
10.5.2 检验日期和时间有效性时参数的顺序不正确 196
10.6 本章小结 196
10.7 跟我上机 196
第2篇 提高篇 198
第11章 MySQL数据库设计 198
11.1 MySQL简介 199
11.1.1 什么是MySQL 199
11.1.2 MySQL特点 199
11.1.3 MySQL 5支持的特性 200
11.2 启动和关闭MySQL服务器 200
11.2.1 启动MySQL服务器 200
11.2.2 连接和断开MySQL服务器 201
11.2.3 关闭MySQL服务器 202
11.3 操作MySQL数据库 203
11.3.1 创建数据库 203
11.3.2 选择数据库 203
11.3.3 删除数据库 204
11.4 MySQL数据类型 204
11.4.1 数字类型 204
11.4.2 字符串类型 205
11.4.3 日期和时间类型 206
11.5 操作MySQL数据表 207
11.5.1 创建数据表 207
11.5.2 查看表结构 208
11.5.3 修改表结构 209
11.5.4 重命名数据表 210
11.5.5 删除数据表 210
11.6 操作MySQL数据 211
11.6.1 插入记录 211
11.6.2 浏览数据库记录 212
11.6.3 修改记录 215
11.6.4 删除记录 215
11.7 phpMyAdmin图形管理工具 216
11.7.1 管理数据库 216
11.7.2 管理数据表 217
11.7.3 管理数据记录 219
11.7.4 导入/导出数据 221
11.8 综合应用 223
11.8.1 管理MySQL数据库及数据表 223
11.8.2 在phpMyAdmin中重置MySQL服务器登录密码 224
11.9 本章常见错误 224
11.9.1 执行修改和删除操作时未指定where条件语句 224
11.9.2 数据库恢复时不存在一个同名的空数据库 225
11.10 本章小结 225
11.11 跟我上机 225
第12章 PHP操作MySQL数据库 226
12.1 PHP操作MySQL数据库的步骤 227
12.2 PHP操作MySQL数据库的方法 228
12.2.1 连接MySQL服务器 228
12.2.2 选择MySQL数据库 229
12.2.3 执行SQL语句 230
12.2.4 将结果集返回到数组中 231
12.2.5 从结果集中获取一行作为对象 233
12.2.6 从结果集中获取一行作为枚举数组 234
12.2.7 获取查询结果集中的记录数 235
12.2.8 释放内存 235
12.2.9 关闭连接 236
12.3 管理MySQL数据库中的数据 236
12.3.1 添加数据 237
12.3.2 编辑数据 238
12.3.3 删除数据 240
12.3.4 批量数据操作 241
12.4 综合应用 242
12.4.1 通用查询 242
12.4.2 高级查询 243
12.4.3 对查询结果分页显示 245
12.5 本章常见错误 248
12.5.1 数据库导致的错误 248
12.5.2 刷新页面重复提交 248
12.6 本章小结 248
12.7 跟我上机 249
第13章 Cookie和Session 251
13.1 Cookie的操作 252
13.1.1 创建Cookie 253
13.1.2 读取Cookie 254
13.1.3 删除Cookie 255
13.2 Session的操作 256
13.2.1 启动Session 257
13.2.2 注册Session 258
13.2.3 使用Session 258
13.2.4 删除Session 259
13.3 Cookie与Session的比较 260
13.4 综合应用 260
13.4.1 通过Session控制页面访问权限 260
13.4.2 Cookie自动登录 262
13.4.3 应用Session控制用户登录时间 264
13.5 本章常见错误 266
13.5.1 在setcookie()函数之前有内容输出 266
13.5.2 应用Session之前没有启动Session 267
13.6 本章小结 267
13.7 跟我上机 267
第14章 图形图像处理技术 268
14.1 GD2函数库简介 269
14.2 激活GD2函数库 269
14.3 常用的图像处理技术 270
14.3.1 创建画布 270
14.3.2 颜色处理 271
14.3.3 输出图像 271
14.3.4 绘制文字 272
14.3.5 绘制直线 274
14.3.6 销毁图像 275
14.4 应用Jpgraph类库绘制图像 275
14.4.1 Jpgraph类库简介 275
14.4.2 Jpgraph类库的安装 275
14.4.3 Jpgraph创建折线图统计图书销售走势 276
14.5 综合应用 278
14.5.1 应用GD2函数在图像上添加文字 278
14.5.2 应用图像处理技术生成验证码 278
14.5.3 Jpgraph创建3D饼形图展示部门业绩比较 280
14.6 本章常见错误 281
14.6.1 应用GD2函数库时代码段上端有HTML输出 281
14.6.2 通过imagettftext()函数不能正常输出中文 281
14.7 本章小结 282
14.8 跟我上机 282
第15章 文件和目录处理技术 283
15.1 基本的文件处理 284
15.1.1 打开文件 284
15.1.2 读取文件中的内容 285
15.1.3 向文件中写入数据 290
15.1.4 关闭文件 292
15.2 目录操作 292
15.2.1 打开目录 292
15.2.2 读取目录结构 292
15.2.3 关闭目录 293
15.3 文件的上传与下载 294
15.3.1 开启文件的上传功能 294
15.3.2 全局变量$FILES的应用 295
15.3.3 移动上传文件 296
15.3.4 文件下载技术 297
15.4 综合应用 298
15.4.1 通过文本文件统计网站访问量 298
15.4.2 规范化的文件上传 300
15.4.3 文本文件的分页输出 302
15.5 本章常见错误 304
15.5.1 在表单中未设置enctype属性 304
15.5.2 打开目录错误 304
15.6 本章小结 304
15.7 跟我上机 304
第16章 面向对象 305
16.1 面向对象的基本概念 306
16.1.1 类 306
16.1.2 对象 306
16.1.3 面向对象的特点 307
16.2 类的声明 307
16.2.1 定义类 308
16.2.2 成员属性 308
16.2.3 成员常量 309
16.2.4 成员方法 309
16.3 类的实例化 310
16.3.1 对象的创建 310
16.3.2 访问类中的成员 310
16.3.3 “$this”和“::” 311
16.3.4 构造方法和析构方法 312
16.4 面向对象的封装 314
16.4.1 公共成员关键字public 314
16.4.2 私有成员关键字private 314
16.4.3 保护成员关键字protected 315
16.5 面向对象的继承 316
16.5.1 继承关键字extends 316
16.5.2 子类调用父类的成员方法 317
16.5.3 覆盖父类方法 318
16.6 抽象类和接口 319
16.6.1 抽象类 319
16.6.2 接口 321
16.7 面向对象实现多态 322
16.7.1 通过继承实现多态 323
16.7.2 通过接口实现多态 324
16.8 面向对象的关键字 324
16.8.1 final关键字 324
16.8.2 static关键字 325
16.8.3 clone关键字 326
16.8.4 对象比较 327
16.8.5 instanceof关键字 328
16.9 面向对象的常用魔术方法 328
16.9 _set()和_get()方法 328
16.9.2 isset()和unset()方法 328
16.9.3 call()方法 329
16.9.4 _toString()方法 329
16.9.5 _autoload()方法 330
16.10 综合应用 331
16.10.1 封装数据库连接类和操作类 331
16.10.2 用面向对象生成图像验证码 333
16.10.3 封装一个显示页码的分页类 334
16.11 本章常见错误 337
16.11.1 在类外直接调用私有变量 337
16.11.2 继承接口时方法没有全部重写 338
16.12 本章小结 338
16.13 跟我上机 338
第17章 PDO数据库抽象层 340
17.1 PDO概述 341
17.1.1 什么是PDO 341
17.1.2 PDO的特点 341
17.1.3 PDO的加载 341
17.2 通过PDO连接数据库 342
17.2.1 PDO的构造函数 342
17.2.2 DSN详解 343
17.3 执行SQL语句 343
17.3.1 exec()方法 343
17.3.2 query()方法 344
17.3.3 预处理语句 345
17.4 获取结果集 346
17.4.1 fetch()方法 346
17.4.2 fetchAll()方法 348
17.4.3 fetchColumn()方法 349
17.5 捕获SQL语句中的错误 351
17.5.1 使用默认模式——PDO::ERRMODE_SILENT 351
17.5.2 使用警告模式——PDO::ERRMODE_WARNING 352
17.5.3 使用异常模式——PDO::ERRMODE_EXCEPTION 353
17.6 错误处理 355
17.6.1 errorCode()方法 355
17.6.2 errorInfo()方法 356
17.7 PDO中的事务处理和存储过程 357
17.7.1 PDO中的事务处理 357
17.7.2 PDO中的存储过程 358
17.8 综合应用 360
17.8.1 添加留言信息 360
17.8.2 修改商品信息 361
17.8.3 删除会员信息 366
17.9 本章常见错误 368
17.9.1 PDO类库未加载 368
17.9.2 未设置数据库编码格式 368
17.10 本章小结 368
17.11 跟我上机 369
第18章 程序调试与错误处理 370
18.1 程序调试的基本策略 371
18.2 常见错误类型 371
18.2.1 语法错误 371
18.2.2 语义错误 374
18.2.3 逻辑错误 374
18.2.4 注释错误 375
18.2.5 运行错误 375
18.3 错误处理机制 375
18.3.1 控制错误显示及显示方式 376
18.3.2 控制错误级别 376
18.4 常用程序调试方法 377
18.4.1 应用die语句进行调试 378
18.4.2 应用mysql_error()语句输出SQL语句的错误 378
18.4.3 应用try{}catch{}语句抛出并捕获异常 379
18.5 错误处理技巧 380
18.5.1 用“@”符号隐藏错误 380
18.5.2 自定义错误信息 381
18.6 综合应用 382
18.6.1 解决数据库乱码问题 382
18.6.2 封装异常处理类 383
18.7 本章常见错误 384
18.7.1 定义SQL语句时字段名不一致大小写不统一 384
18.7.2 全局变量register_globals的值设置为On 385
18.8 本章小结 385
18.9 跟我上机 385
第19章 Ajax技术 387
19.1 Ajax概述 388
19.1.1 什么是Ajax 388
19.1.2 Ajax的开发模式 388
19.1.3 Ajax的优点 388
19.2 Ajax技术的组成 389
19.2.1 JavaScript脚本语言 389
19.2.2 XMLHttpRequest对象 389
19.2.3 XML语言 393
19.2.4 DOM 393
19.2.5 CSS 394
19.3 Ajax与PHP的交互 394
19.3.1 通过GET方式与PHP进行交互 394
19.3.2 通过POST方式与PHP进行交互 396
19.4 Ajax开发注意事项 399
19.5 综合应用 400
19.5.1 在PHP中应用Ajax技术检测用户名 400
19.5.2 在PHP中应用Ajax技术实现博客文章类别添加 402
19.5.3 使用jQuery制作级联下拉列表框 404
19.6 本章常见错误 406
19.6.1 在应用Ajax过程中出现乱码 406
19.6.2 不能及时获取最新数据 407
19.7 本章小结 407
19.8 跟我上机 408
第20章 Smarty模板技术 410
20.1 Smarty简介 411
20.2 Smarty的安装配置 411
20.2.1 Smarty下载和安装 411
20.2.2 Smarty配置 412
20.2.3 第一个Smarty程序 413
20.3 Smarty模板设计 414
20.3.1 Smarty模板文件 414
20.3.2 注释 415
20.3.3 变量 415
20.3.4 修饰变量 417
20.3.5 流程控制 419
20.3.6 内建函数 423
20.4 Smarty程序设计 425
20.4.1 Smarty中的常用方法 425
20.4.2 Smarty的配置变量 426
20.5 综合应用 426
20.5.1 Smarty模板创建网页框架 426
20.5.2 分页输出会员信息 428
20.6 本章常见错误 432
20.6.1 Smarty模板的配置错误 432
20.6.2 模板引擎的解析错误 432
20.7 本章小结 433
20.8 跟我上机 433
第3篇 实战篇 436
第21章 明日企业网 436
21.1 概述 437
21.2 开发背景 437
21.3 需求分析 437
21.4 功能结构 439
21.5 数据库设计 439
21.5.1 数据库概念设计 439
21.5.2 创建数据库及数据表 441
21.6 技术攻关 442
21.6.1 Smarty模板 442
21.6.2 最简单的网页框架 444
21.6.3 PDO数据库抽象层 444
21.6.4 封装分页类 445
21.7 首页设计 446
21.7.1 首页概述 447
21.7.2 首页技术分析 447
21.7.3 首页的实现过程 448
21.8 产品展示设计 450
21.8.1 产品展示概述 450
21.8.2 产品展示技术分析 450
21.8.3 产品展示实现过程 451
21.9 后台管理系统设计 453
21.9.1 后台管理系统概述 453
21.9.2 后台管理系统技术分析 453
21.9.3 后台管理系统实现过程 455
21.10 本章小结 460
第22章 应用Smarty模板开发电子商务平台 461
22.1 项目描述 462
22.2 系统分析 462
22.2.1 需求分析 462
22.2.2 编写项目计划书 462
22.3 系统设计 463
22.3.1 系统目标 463
22.3.2 系统功能结构 463
22.3.3 系统流程图 464
22.4 系统开发环境 465
22.5 搭建系统框架 465
22.6 数据库与数据表的设计 465
22.6.1 数据库分析 465
22.6.2 创建数据库和数据表 467
22.7 公共文件设计 468
22.7.1 数据库连接文件 469
22.7.2 Smarty配置文件 469
22.7.3 XMLHttpRequest对象文件 469
22.7.4 表单样式文件 470
22.8 前台首页设计 472
22.9 登录模块设计 474
22.9.1 用户注册 474
22.9.2 用户登录 480
22.9.3 找回密码 482
22.10 会员信息模块设计 487
22.10.1 会员中心 487
22.10.2 安全退出 490
22.11 商品展示模块设计 491
22.11.1 创建PHP页 491
22.11.2 创建模板页 492
22.11.3 js脚本页面 493
22.12 购物车模块设计 493
22.12.1 添加商品 493
22.12.2 显示购物车 496
22.12.3 更改商品数量 498
22.12.4 删除商品 498
22.12.5 保存购物车 501
22.13 收银台模块设计 503
22.13.1 显示订单 503
22.13.2 填写订单 504
22.13.3 处理订单 505
22.13.4 反馈订单 507
22.13.5 查询订单 508
22.14 后台首页设计 511
22.14.1 后台首页布局 511
22.14.2 DIV4+JavaScript+CSS实现树状菜单 512
22.15 类别管理模块设计 513
22.15.1 添加类别 513
22.15.2 查看类别 516
22.16 订单管理模块设计 520
22.17 开发过程中的常见问题 523
22.17.1 使用js脚本获取、输出标签内容 523
22.17.2 解决Ajax的乱码问题 524
22.17.3 禁用页面缓存 524
22.17.4 使用浮动框架做关联菜单 524
22.17.5 防止站外链接 525
22.17.6 在新窗口中使用Session 525
22.17.7 判断上传文件格式 526
22.18 错误分析 526
22.18.1 数据库导致的错误 526
22.18.2 Smarty模板的配置错误 527
22.19 本章小结 529