当前位置:首页 > 工业技术
JavaScript编程全解
JavaScript编程全解

JavaScript编程全解PDF电子书下载

工业技术

  • 电子书积分:14 积分如何计算积分?
  • 作 者:(日)井上诚一郎,(日)土江拓郎,(日)滨边将太著;陈筱烟译
  • 出 版 社:北京:人民邮电出版社
  • 出版年份:2013
  • ISBN:9787115333414
  • 页数:406 页
图书介绍:本书的前半部分介绍JavaScript的语言基础,并通过大量JavaScript代码以及细致的语法说明,帮助读者彻底厘清语法细节。后半部分主要介绍包括客户端JavaScript、HTML5、Web API以及服务器端JavaScript等相关的应用领域。同时讲解了JavaScript在HTML的DOM、HTML5、WebAPI、Node.js等环境中的应用,以及ECMAScript5的最新变化。
《JavaScript编程全解》目录
标签:边将 编程

第1部分 JavaScript概要 1

第1章 JavaScript概要 2

1.1 JavaScript概要 2

1.2 JavaScript的历史 2

1.3 ECMAScript 3

1.3.1 JavaScript的标准化 3

1.3.2 被放弃的ECMAScript第4版 4

1.4 JavaScript的版本 4

1.5 JavaScript实现方式 5

1.6 JavaScript运行环境 6

1.6.1 核心语言 6

1.6.2 宿主对象 7

1.7 JavaScript相关环境 7

1.7.1 库 7

1.7.2 源代码压缩 7

1.7.3 集成开发环境 8

第2部分 地区 JavaScript的语言基础 9

第2章 JavaScript基础 10

2.1 JavaScript的特点 10

2.2 关于编排格式 11

2.3 变量的基础 12

2.3.1 变量的使用方法 12

2.3.2 省略var 13

2.3.3 常量 13

2.4 函数基础 13

2.4.1 函数的定义 13

2.4 2 函数的声明与调用 14

2.4.3 匿名函数 14

2.4.4 函数是一种对象 15

2.5 对象的基础 16

2.5.1 对象的定义 16

2.5.2 对象字面量表达式与对象的使用 16

2.5.3 属性访问 17

2.5.4 属性访问(括号方式) 17

2.5.5 方法 18

2.5.6 new表达式 18

2.5.7 类与实例 18

2.5.8 对类的功能的整理 18

2.5.9 对象与类型 19

2.6 数组的基础 19

第3章 JavaScript的数据类型 21

3.1 数据类型的定义 21

3.1.1 在数据类型方面与Java作比较 21

3.1.2 基本数据类型和引用类型 22

3.2 内建数据类型概要 22

3.3 字符串型 23

3.3 1 字符串字面量 23

3.3.2 字符串型的运算 24

3.3.3 字符串型的比较 24

3.3.4 字符串类(String类) 25

3.3.5 字符串对象 26

3.3.6 避免混用字符串值和字符串对象 27

3.3.7 调用String函数 27

3.3.8 String类的功能 27

3.3.9 非破坏性的方法 29

3.4 数值型 29

3.4.1 数值字面量 29

3.4.2 数值型的运算 30

3.4.3 有关浮点数的常见注意事项 30

3.4.4 数值类(Number类) 31

3.4.5 调用Number函数 31

3.4.6 Number类的功能 32

3.4.7 边界值与特殊数值 33

3.4.8 NaN 34

3.5 布尔型 35

3.5 1 布尔值 35

3.5.2 布尔类(Boolean类) 36

3.5.3 Boolean类的功能 36

3.6 null型 37

3.7 undefined型 37

3.8 Object类型 38

3.9 数据类型转换 39

3.9.1 从字符串值转换为数值 39

3.9.2 从数值转换为字符串值 40

3.9.3 数据类型转换的惯用方法 40

3.9.4 转换为布尔型 41

3.9.5 其他的数据类型转换 42

3.9.6 从Object类型转换为基本数据类型 42

3.9.7 从基本数据类型转换为Object类型 43

第4章 语句、表达式和运算符 45

4.1 表达式和语句的构成 45

4.2 保留字 45

4.3 标识符 46

4.4 字面量 47

4.5 语句 47

4.6 代码块(复合语句) 48

4.7 变量声明语句 48

4.8 函数声明语句 48

4.9 表达式语句 48

4.1 0 空语句 49

4.1 1 控制语句 49

4.1 2 if-else语句 50

4.1 3 switch-case语句 52

4.1 4 循环语句 54

4.1 5 while语句 55

4.1 6 do-while语句 56

4.1 7 for语句 57

4.1 8 for in语句 58

4.1 8.1 数列与for in语句 59

4.1 8.2 在使用for in语句时需要注意的地方 60

4.1 9 for each in语句 60

4.2 0 break语句 61

4.2 1 continue语句 61

4.2 2 通过标签跳转 62

4.2 3 return语句 63

4.2 4 异常 63

4.2 5 其他 64

4.2 6 注释 65

4.2 7 表达式 65

4.2 8 运算符 65

4.2 9 表达式求值 66

4.3 0 运算符的优先级以及结合律 66

4.3 1 算术运算符 67

4.3 2 字符串连接运算符 68

4.3 3 相等运算符 68

4.3 4 比较运算符 69

4.3 5 in运算符 70

4.3 6 instanceof运算符 71

4.3 7 逻辑运算符 71

4.3 8 位运算符 72

4.3 9 赋值运算符 72

4.4 0 算术赋值运算符 73

4.4 1 条件运算符(三目运算符) 73

4.4 2 typeof运算符 73

4.4 3 new运算符 74

4.4 4 delete运算符 74

4.4 5 void运算符 74

4.4 6 逗号(,)运算符 74

4.4 7 点运算符和中括号运算符 75

4.4 8 函数调用运算符 75

4.4 9 运算符使用以及数据类型转换中需要注意的地方 75

第5章 变量与对象 76

5.1 变量的声明 76

5.2 变量与引用 76

5.2.1 函数的参数(值的传递) 78

5.2.2 字符串与引用 79

5.2.3 对象与引用相关的术语总结 79

5.3 变量与属性 80

5.4 变量的查找 81

5.5 对变量是否存在的检验 81

5.6 对象的定义 82

5.6.1 抽象数据类型与面向对象 82

5.6.2 实例间的协作关系与面向对象 83

5.6.3 JavaScript的对象 83

5.7 对象的生成 83

5.7.1 对象字面量 83

5.7.2 构造函数与new表达式 85

5.7.3 构造函数与类的定义 87

5.8 属性的访问 87

5.8.1 属性值的更新 88

5.8.2 点运算符与中括号运算符在使用上的区别 88

5.8.3 属性的枚举 89

5.9 作为关联数组的对象 89

5.9.1 关联数组 89

5.9.2 作为关联数组的对象的注意点 90

5.1 0 属性的属性 91

5.1 1 垃圾回收 92

5.1 2 不可变对象 92

5.1 2.1 不可变对象的定义 92

5.1 2.2 不可变对象的作用 92

5.1 2.3 实现不可变对象的方式 93

5.1 3 方法 94

5.1 4 this引用 94

5.1 4.1 this引用的规则 94

5.1 4.2 this引用的注意点 95

5.1 5 apply与call 96

5.1 6 原型继承 97

5.1 6.1 原型链 97

5.1 6.2 原型链的具体示例 99

5.1 6.3 原型继承与类 100

5.1 6.4 对于原型链的常见误解以及_proto_属性 100

5.1 6.5 原型对象 101

5.1 6.6 ECMAScript第5版与原型对象 101

5.1 7 对象与数据类型 102

5.1 7.1 数据类型判定(constructor属性) 102

5.1 7.2 constructor属性的注意点 102

5.1 7.3 数据类型判定(instance运算与isPrototypeOf方法) 103

5.1 7.4 数据类型判定(鸭子类型) 103

5.1 7.5 属性的枚举(原型继承的相关问题) 104

5.1 8 ECMAScript第5版中的Object类 105

5.1 8.1 属性对象 105

5.1 8.2 访问器的属性 106

5.1 9 标准对象 108

5.2 0 Object类 108

5.2 1 全局对象 110

5.2 1.1 全局对象与全局变量 110

5.2 1.2 Math对象 111

5.2 1.3 Error对象 112

第6章 函数与闭包 113

6.1 函数声明语句与匿名函数表达式 113

6.2 函数调用的分类 113

6.3 参数与局部变量 114

6.3.1 arguments对象 114

6.3.2 递归函数 114

6.4 作用域 115

6.4.1 浏览器与作用域 116

6.4.2 块级作用域 116

6.4.3 let与块级作用域 117

6.4.4 嵌套函数与作用域 119

6.4.5 变量隐藏 119

6.5 函数是一种对象 120

6.6 Function类 122

6.7 嵌套函数声明与闭包 123

6.7.1 对闭包的初步认识 123

6.7.2 闭包的原理 123

6.7.3 闭包中需要注意的地方 126

6.7.4 防范命名空间的污染 127

6.7.5 闭包与类 129

6.8 回调函数设计模式 130

6.8.1 回调函数与控制反转 130

6.8.2 JavaScript与回调函数 131

第7章 数据处理 134

7.1 数组 134

7.1.1 JavaScript的数组 134

7.1.2 数组元素的访问 135

7.1.3 数组的长度 136

7.1.4 数组元素的枚举 136

7.1.5 多维数组 137

7.1.6 数组是一种对象 138

7.1.7 Array类 139

7.1.8 数组对象的意义 140

7.1.9 数组的习惯用法 141

7.1.1 0 数组的内部实现 144

7.1.1 1 数组风格的对象 145

7.1.1 2 迭代器 145

7.1.1 3 生成器 147

7.1.1 4 数组的内包 149

7.2 JSON 149

7.2.1 JSON字符串 149

7.2.2 JSON对象 150

7.3 日期处理 151

7.4 正则表达式 153

7.4.1 正则表达式的定义 153

7.4.2 正则表达式相关的术语 154

7.4.3 正则表达式的语法 154

7.4.4 JavaScript中的正则表达式 156

7.4.5 正则表达式程序设计 157

7.4.6 字符串对象与正则表达式对象 158

第3部分 地区 客户端JavaScript 161

第8章 客户端JavaScript与HTML 162

8.1 客户端JavaScript的重要性 162

8.1.1 Web应用程序的发展 162

8.1.2 JavaScript的性能提升 162

8.1.3 JavaScript的作用 163

8.2 HTML与JavaScript 163

8.2.1 网页显示过程中的处理流程 163

8.2.2 JavaSoript的表述方式及其执行流程 163

8.2.3 执行流程的小结 166

8.3 运行环境与开发环境 166

8.3.1 运行环境 166

8.3.2 开发环境 166

8.4 调试 167

8.4.1 alert 167

8.4.2 console 167

8.4.3 nerror 169

8.4.4 Firebug,Web Inspector(Developer Tools)Opera Dragonfly 169

8.5 跨浏览器支持 171

8.5.1 应当提供支持的浏览器 171

8.5.2 实现方法 172

8.6 Window对象 174

8.6.1 Navigator对象 174

8.6.2 Location对象 174

8.6.3 History对象 175

8.6.4 Screen对象 176

8.6.5 对Window对象的引用 176

8.6.6 Document对象 176

第9章 DOM 177

9.1 DOM的定义 177

9.1.1 DOM Level 1 177

9.1.2 DOM Level 2 177

9.1.3 DOM Level 3 178

9.1.4 DOM的表述方式 178

9.2 DOM的基础 179

9.2.1 标签、元素、节点 179

9.2.2 DOM操作 179

9.2.3 Document对象 179

9.3 节点的选择 180

9.3.1 通过ID检索 180

9.3.2 通过标签名检索 180

9.3.3 通过名称检索 184

9.3.4 通过类名检索 184

9.3.5 父节点、子节点、兄弟节点 185

9.3.6 XPath 187

9.3.7 Selector API 189

9.4 节点的创建与新增 190

9.5 节点的内容更改 190

9.6 节点的删除 190

9.7 innerHTML/textContent 190

9.7.1 innerHTML 190

9.7.2 textContent 191

9.8 DOM操作的性能 191

第10章 事件 192

10.1 事件驱动程序设计 192

10.2 事件处理程序/事件侦听器的设定 192

10.2.1 指定为HTML元素的属性 193

10.2.2 指定为DOM元素的属性 194

10.2.3 通过EventTarget.addEventListener()进行指定 194

10.2.4 事件处理程序/事件侦听器内的this引用 196

10.3 事件的触发 196

10.4 事件的传播 196

10.4.1 捕获阶段 197

10.4.2 目标阶段 197

10.4.3 事件冒泡阶段 197

10.4.4 取消 197

10.5 事件所具有的元素 198

10.6 标准事件 199

10.6.1 DOM Level 2中所定义的事件 199

10.6.2 DOM Level 3中所定义的事件 200

10.7 自定义事件 202

第11章 客户端JavaScript实践 203

11.1 样式 203

11.1.1 样式的变更方法 203

11.1.2 位置的设定 207

11.1.3 位置 208

11.1.4 动画 209

11.2 AJAX 210

11.2.1 异步处理的优点 210

11.2.2 XMLHttpRequest 210

11.2.3 基本的处理流程 210

11.2.4 同步通信 212

11.2.5 超时 212

11.2.6 响应 213

11.2.7 跨源限制 214

11.2.8 跨源通信 214

11.2.9 JSONP 214

11.2.10 iframe攻击(iframe hack) 215

11.2.11 window.postMessage 218

11.2.12 XMLHttpRequest Level 2 219

11.2.13 跨源通信的安全问题 219

11.3 表单 219

11.3.1 表单元素 219

11.3.2 表单控件 221

11.3.3 内容验证 221

11.3.4 可用于验证的事件 222

11.3.5 使用表单而不产生页面跳转的方法 222

第12章 库 224

12.1 使用库的原因 224

12.2 jQuery的特征 224

12.3 jQuery的基本概念 225

12.3.1 使用实例 225

12.3.2 链式语法 226

12.4 $函数 227

12.4.1 抽取与选择器相匹配的元素 227

12.4.2 创建新的DOM元素 227

12.4.3 将已有的DOM元素转换为jQuery对象 227

12.4.4 对DOM构造完成后的事件侦听器进行设定 227

12.5 通过jQuery进行DOM操作 228

12.5.1 元素的选择 228

12.5.2 元素的创建·添加·替换·删除 230

12.6 通过jQuery处理事件 231

12.6.1 事件侦听器的注册·删除 231

12.6.2 事件专用的事件侦听器注册方法 232

12.6.3 ready()方法 232

12.7 通过jQuery对样式进行操作 233

12.7.1 基本的样式操作 233

12.7.2 动画 234

12.8 通过jQuery进行AJAX操作 235

12.8.1 AJAX()函数 235

12.8.2 AJAX()的包装函数 236

12.8.3 全局事件 237

12.9 Deferred 237

12.9.1 Deferred的基本概念 237

12.9.2 状态迁移 238

12.9.3 后续函数 239

12.9.4 并行处理 241

12.10 jQuery插件 241

12.10.1 使用jQuery插件 241

12.10.2 创建jQuery插件 242

12.11 与其他库共同使用 243

12.11.1 $对象的冲突 243

12.11.2 避免$对象的冲突 243

12.12 库的使用方法 244

第4部分 HTML5 245

第13章 HTML5概要 246

13.1 HTML5的历史 246

13.2 HTML5的现状 247

13.2.1 浏览器的支持情况 247

13.2.2 Web应用程序与原生应用程序 248

13.3 HTML5的概要 248

第14章 Web应用程序 250

14.1 History API 250

14.1.1 History API的定义 250

14.1.2 哈希片段 250

14.1.3 接口 251

14.2 ApplicationCache 255

14.2.1 关于缓存管理 255

14.2.2 缓存清单文件 255

14.2.3 ApplicationCache API 258

14.2.4 在线与离线 259

第15章 与桌面应用的协作 260

15.1 Drag Drop API 260

15.1.1 Drag Drop API的定义 260

15.1.2 接口 261

15.1.3 基本的拖动与释放 262

15.1.4 自定义显示 263

15.1.5 文件的Drag-In/Drag-Out 265

15.2 File API 267

15.2.1 File API的定义 267

15.2.2 File对象 267

15.2.3 FileReader 269

15.2.4 data URL 271

15.2.5 FileReaderSync 273

第16章 存储 274

16.1 Web Storage 274

16.1.1 Web Storage的定义 274

16.1.2 基本操作 275

16.1.3 storage事件 277

16.1.4 关于Cookie 277

16.1.5 命名空间的管理 278

16.1.6 版本的管理 279

16.1.7 对IocalStorage的模拟 279

16.2 Indexed Database 280

16.2.1 Indexed Database的定义 280

16.2.2 基础架构 280

16.2.3 连接数据库 281

16.2.4 对象存储的创建 281

16.2.5 数据的添加删除引用 282

16.2.6 索引的创建 283

16.2.7 数据的检索与更新 284

16.2.8 数据的排序 285

16.2.9 事务 285

16.2.1 0 同步API 286

第17章 WebSocket 287

17.1 WebSocket概要 287

17.1.1 WebSocket的定义 287

17.1.2 现有的通信技术 287

17.1.3 WebSocket的标准 290

17.1.4 WebSocket的执行方式 290

17.2 基本操作 291

17.2.1 连接的建立 291

17.2.2 消息的收发 291

17.2.3 连接的切断 292

17.2.4 连接的状态确认 292

17.2.5 二进制数据的收发 293

17.2.6 WebSocket实例的属性一览 293

17.3 WebSocket实践 294

17.3.1 Node.js的安装 294

17.3.2 服务器端的实现 295

17.3.3 客户端的实现 295

17.3.4 客户端的实现2 296

第18章 Web Workers 298

18.1 Web Workers概要 298

18.1.1 Web Workers的定义 298

18.1.2 Web Workers的执行方式 298

18.2 基本操作 299

18.2.1 工作线程的创建 299

18.2.2 主线程一侧的消息收发 299

18.2.3 工作线程一侧的消息收发 300

18.2.4 工作线程的删除 300

18.2.5 外部文件的读取 301

18.3 Web Worker实践 301

18.3.1 工作线程的使用 301

18.3.2 中断对工作线程的处理 302

18.4 共享工作线程 304

18.4.1 共享工作线程的定义 304

18.4.2 共享工作线程的创建 304

18.4.3 共享工作线程的消息收发 305

18.4.4 共享工作线程的删除 306

18.4.5 共享工作线程的应用实例 306

第5部分 Web API 309

第19章 Web API的基础 310

19.1 Web API与Web服务 310

19.2 Web API的历史 311

19.2.1 Web抓取 311

19.2.2 语义网 311

19.2.3 XML 311

19.2.4 Atom 312

19.2.5 JSON 312

19.2.6 SOAP 313

19.2.7 REST 313

19.2.8 简单总结 313

19.3 Web API的组成 314

19.3.1 Web API的形式 314

19.3.2 Web API的使用 315

19.3.3 RESTful API 315

19.3.4 API密钥 316

19.4 用户验证与授权 317

19.4.1 Web应用程序的会话管理 317

19.4.2 会话管理与用户验证 318

19.4.3 Web API与权限 319

19.4.4 验证与授权 320

19.4.5 OAuth 321

第20章 Web的实例 323

20.1 Web API的分类 323

20.2 Google Translate API 324

20.2.1 准备 325

20.2.2 执行方式的概要 325

20.2.3 使用了Web API的代码示例 326

20.2.4 微件(Google Translate Element) 327

20.3 Google Maps API 328

20.3.1 Google Static Maps API 328

20.3.2 我的地图 329

20.3.3 Google Maps API的概要 330

20.3.4 简单的Google Maps API示例 330

20.3.5 事件 331

20.3.6 Geolocation API与Geocoding API 333

20.4 Yahool! Flickr 334

20.4.1 Flickr Web API的使用 335

20.4.2 Flickr Web API的使用实例 336

20.5 Twitter 337

20.5.1 搜索API 337

20.5.2 REST API 338

20.5.3 Twitter JS API@anywhere 339

20.5.4 Twitter Widget 341

20.6 Facebook 341

20.6.1 Facebook应用的发展历程 341

20.6.2 Facebook的JavaScript API 343

20.6.3 Facebook的插件 344

20.7 OpenSocial 345

第6部分 服务器端JavaScript 351

第21章 服务器端JavaScript与Node.js 352

21.1 服务器端JavaScript的动向 352

21.2 CommonJS 352

21.2.1 CommonJS的定义 352

21.2.2 CommonJS的动向 353

21.2.3 模块功能 353

21.3 Node.js 355

21.3.1 Node.js概要 355

21.3.2 node指令 359

21.3.3 npm与包 359

21.3.4 console模块 360

21.3.5 util模块 361

21.3.6 process对象 362

21.3.7 全局对象 363

21.3.8 Node.js程序设计概要 363

21.3.9 事件API 365

21.3.10 缓冲 369

21.3 11 流 372

第22章 Node.js程序设计实践 374

22.1 HTTP服务器处理 374

22.1.1 HTTP服务器处理的基本流程 374

22.1.2 请求处理 375

22.1.3 响应处理 376

22.1.4 POST请求处理 377

22.2 HTTP客户端处理 378

22.3 HTTPS处理 379

22.3.1 通过openssl指令发布自签名证书的方法 379

22.3.2 HTTPS服务器 379

22.4 Socket.IO与WebSocket 380

22.5 下层网络程序设计 381

22.5.1 下层网络处理 381

22.5.2 套接字的定义 382

22.5.3 套接字程序设计的基本结构 382

22.5.4 套接字程序设计的具体实例 384

22.6 文件处理 385

22.6.1 本节的范例代码 385

22.6.2 文件的异步处理 386

22.6.3 文件的同步处理 386

22.6.4 文件操作相关函数 387

22.6.5 文件读取 387

22.6.6 文件写入 388

22.6.7 目录操作 389

22.6.8 对文件更改的监视 390

22.6.9 文件路径 390

22.7 定时器 390

22.8 Express 391

22.8.1 URL路由 392

22.8.2 请求处理 392

22.8.3 响应处理 393

22.8.4 scaffold创建功能 393

22.8.5 MVC架构 393

22.8.6 模板语言Jade 394

22.8.7 MongoDB(数据库) 395

22.8.8 Mongoose的实例 397

22.8.9 使用了Express与Mongoose的Web应用程序 398

后记 401

索引 403

相关图书
作者其它书籍
返回顶部