jQuery技术内幕:深入解析jQuery架构设计与实现原理》

基本信息

作者: 高云

出版社:机械工业出版社

ISBN:9787111440826

上架时间:2014-1-10

出版日期:2014 年1月

开本:16开

页码:1

版次:1-1

所属分类:计算机

更多关于》》》 jQuery技术内幕:深入解析jQuery架构设计与实现原理》

 

内容简介

书籍

计算机书籍

  《jquery技术内幕:深入解析jquery架构设计与实现原理》由阿里巴巴资深前端开发工程师撰写,从源代码角度全面而系统地解读了jquery的17个模块的架构设计理念和内部实现原理,旨在帮助读者参透jquery中的实现技巧和技术精髓,同时本书也对广大开发者如何通过阅读源代码来提升编码能力和软件架构能力提供了指导。

  《jquery技术内幕:深入解析jquery架构设计与实现原理》首先通过“总体架构”梳理了各个模块的分类、功能和依赖关系,让大家对jquery的工作原理有大致的印象;进而通过“构造jquery对象”章节分析了构造函数jquery()的各种用法和内部构造过程;接着详细分析了底层支持模块的源码实现,包括:选择器sizzle、异步队列deferred、数据缓存data、队列queue、浏览器功能测试support;最后详细分析了功能模块的源码实现,包括:属性操作attributes、事件系统events、dom遍历traversing、dom操作manipulation、样式操作css、异步请求ajax、动画effects。

  《jquery技术内幕:深入解析jquery架构设计与实现原理》在分析每个模块时均采用由浅入深的方式,先概述功能、用法、结构和实现原理,然后介绍关键步骤和分析源码实现。让读者不仅知其然,而且知其所以然。事实上,本书的根本价值在于传达一种通过阅读源码快速成长的方式。无论是前端新人,还是经验丰富的老手,只要是对javascript感兴趣的开发人员,都会从本书中受益。

目录

《jquery技术内幕:深入解析jquery架构设计与实现原理》

前言

第一部分 总体架构

第1章 总体架构 2

1.1 设计理念 2

1.2 总体架构 2

1.3 自调用匿名函数 4

1.4 总结 6

第二部分 构造jquery对象

第2章 构造jquery对象 8

2.1 构造函数jquery() 8

2.1.1 jquery( selector [, context] ) 9

2.1.2 jquery( html [, ownerdocument] )、jquery( html, props ) 9

2.1.3 jquery( element )、jquery( elementarray ) 10

2.1.4 jquery( object ) 10

2.1.5 jquery( callback ) 11

2.1.6 jquery( jquery object ) 11

2.1.7 jquery() 11

2.2 总体结构 11

2.3 jquery.fn.init( selector, context, rootjquery ) 13

.2.3.1 12个分支 13

2.3.2 源码分析 14

2.3.3 小结 21

2.4 jquery.buildfragment( args, nodes, scripts ) 22

2.4.1 实现原理 22

2.4.2 源码分析 22

2.4.3 小结 26

2.5 jquery.clean( elems, context, fragment, scripts ) 27

2.5.1 实现原理 27

2.5.2 源码分析 27

2.5.3 小结 39

2.6 jquery.extend()、jquery.fn.extend() 40

2.6.1 如何使用 40

2.6.2 源码分析 40

2.7 原型属性和方法 43

2.7.1 .selector、.jquery、.length、.size() 44

2.7.2 .toarray()、.get( [index] ) 45

2.7.3 .each( function(index, element) )、jquery.each( collection, callback (indexinarray, valueofelement) ) 46

2.7.4 .map( callback(index, domelement) )、jquery.map( arrayorobject, callback(value, indexorkey) ) 47

2.7.5 .pushstack( elements, name, arguments ) 49

2.7.6 .end() 51

2.7.7 .eq( index )、.first()、.last()、.slice( start [, end] ) 51

2.7.8 .push( value, ... )、.sort( [orderfunc] )、.splice( start,deletecount, value, ... ) 52

2.7.9 小结 53

2.8 静态属性和方法 54

2.8.1 jquery.noconflict( [removeall] ) 55

2.8.2 类型检测:jquery.isfunction( obj )、jquery.isarray( obj )、jquery.iswindow( obj )、jquery.isnumeric( value )、jquery.type( obj )、jquery.isplainobject( object )、jquery.isemptyobject( object ) 56

2.8.3 解析json和xml:jquery.parsejson( data )、jquery.parsexml( data ) 60

2.8.4 jquery.globaleval( code ) 65

2.8.5 jquery.camelcase( string ) 65

2.8.6 jquery.nodename( elem, name ) 66

2.8.7 jquery.trim( str ) 67

2.8.8 数组操作方法:jquery.makearray( obj )、jquery.inarray( value, array [, fromindex] )、jquery.merge( first, second )、jquery.grep( array, function(elementofarray, indexinarray) [, invert] ) 68

2.8.9 jquery.guid、jquery.proxy( function, context ) 72

2.8.10 jquery.access( elems, key, value, exec, fn( elem, key, value ), pass ) 74

2.8.11 jquery.error( message )、jquery.noop()、jquery.now() 75

2.8.12 浏览器嗅探:jquery.uamatch( ua )、jquery.browser 76

2.8.13 小结 77

2.9 总结 77

第三部分 底层支持模块

第3章 选择器sizzle 80

3.1 总体结构 81

3.2 选择器表达式 83

3.3 设计思路 84

3.4 sizzle( selector, context, results, seed ) 86

3.5 正则chunker 94

3.6 sizzle.find( expr, context, isxml ) 94

3.7 sizzle.filter( expr, set, inplace, not ) 99

3.8 sizzle.selectors.relative 103

3.8.1 "+" 105

3.8.2 "]" 106

3.8.3 "" 108

3.8.4 "~" 108

3.8.5 dircheck( dir, cur, donename, checkset, nodecheck, isxml ) 109

3.8.6 dirnodecheck( dir, cur, donename, checkset, nodecheck, isxml ) 111

3.9 sizzle.selectors 112

3.9.1 sizzle.selectors.order 112

3.9.2 sizzle.selectors.match/leftmatch 113

3.9.3 sizzle.selectors.find 122

3.9.4 sizzle.selectors.prefilter 123

3.9.5 sizzle.selectors.filters 129

3.9.6 sizzle.selectors.setfilters 132

3.9.7 sizzle.selectors.filter 133

3.10 工具方法 140

3.10.1 sizzle.uniquesort( results ) 140

3.10.2 sortorder( a, b ) 141

3.10.3 sizzle.contains( a, b ) 144

3.10.4 sizzle.error( msg ) 145

3.10.5 sizzle.gettext( elem ) 145

3.11 便捷方法 146

3.11.1 sizzle.matches( expr, set ) 146

3.11.2 sizzle.matchesselector( node, expr ) 146

3.12 jquery扩展 147

3.12.1 暴露sizzle给jquery 147

3.12.2 .find( selector ) 148

3.12.3 .has( target ) 149

3.12.4 .not( selector )、.filter( selector ) 150

3.12.5 .is( selector ) 152

3.12.6 .closest( selectors, context ) 153

3.12.7 .index( elem ) 154

3.12.8 .add( selector, context ) 155

3.12.9 jquery.filter( expr, elems, not ) 156

3.12.10 :animated 157

3.12.11 hidden、:visible 157

3.13 总结 158

第4章 异步队列deferred object 160

4.1 jquery.callbacks( flags ) 161

4.1.1 实现原理和总体结构 162

4.1.2 源码分析 163

4.1.3 小结 174

4.2 jquery.deferred( func ) 174

4.2.1 实现原理和总体结构 176

4.2.2 源码分析 177

4.2.3 小结 183

4.3 jquery.when( deferreds ) 184

4.3.1 实现原理 185

4.3.2 源码分析 185

4.4 异步队列在jquery中的应用 187

4.5 总结 188

第5章 数据缓存data 189

5.1 实现原理 189

5.1.1 为dom元素附加数据 189

5.1.2 为javascript对象附加数据 191

5.2 总体结构 192

5.3 jquery.acceptdata( elem ) 193

5.4 jquery.data( elem, name, data, pvt )、jquery._data( elem, name, data, pvt ) 194

5.4.1 如何使用 194

5.4.2 源码分析 194

5.4.3 jquery._data( elem, name, data ) 199

5.4.4 小结 201

5.5 .data( key,value ) 201

5.5.1 如何使用 201

5.5.2 源码分析 202

5.5.3 小结 206

5.6 jquery.removedata( elem,name,pvt )、.removedata( key ) 207

5.6.1 如何使用 207

5.6.2 源码分析 207

5.6.3 小结 212

5.7 .removedata( key ) 213

5.8 jquery.cleandata( elems ) 213

5.8.1 应用场景 213

5.8.2 源码分析 214

5.8.3 小结 217

5.9 jquery.hasdata( elem ) 217

5.10 总结 218

第6章 队列queue 219

6.1 如何使用 219

6.1.1 ajax队列 220

6.1.2 动画队列+ ajax队列 220

6.1.3 基于javascript对象 221

6.2 实现原理 221

6.3 总体结构 222

6.4 jquery.queue( elem,type,data ) 223

6.5 jquery.dequeue( elem,type ) 224

6.6 .queue( type,data ) 227

6.7 .dequeue( type ) 228

6.8 .delay( time,type ) 229

6.9 .clearqueue( type ) 230

6.10 jquery._mark( elem,type )、jquery._unmark( force,elem,type ) 230

6.11 .promise( type,object ) 232

6.11.1 如何使用 232

6.11.2 实现原理 233

6.11.3 源码分析 233

6.11.4 handlequeuemarkdefer( elem,type,src ) 235

6.12 总结 237

第7章 浏览器功能测试support 238

7.1 总体结构 238

7.2 dom测试(15项) 241

7.2.1 leadingwhitespace 241

7.2.2 tbody 242

7.2.3 htmlserialize 243

7.2.4 hrefnormalized 245

7.2.5 checkon 246

7.2.6 noclonechecked 248

7.2.7 optselected 250

7.2.8 optdisabled 251

7.2.9 getsetattribute 253

7.2.10 deleteexpando 256

7.2.11 enctype 258

7.2.12 html5clone 259

7.2.13 radiovalue 261

7.2.14 checkclone 263

7.2.15 appendchecked 264

7.3 样式测试(3项) 266

7.3.1 style 266

7.3.2 opacity 268

7.3.3 cssfloat 272

7.4 盒模型测试(10项) 273

7.4.1 reliablemarginright 273

7.4.2 reliablehiddenoffsets 276

7.4.3 boxmodel 278

7.4.4 inlineblockneedslayout 280

7.4.5 shrinkwrapblocks 282

7.4.6 doesnotaddborder、doesaddborderfortableandcells 285

7.4.7 fixedposition 287

7.4.8 subtractsborderforoverflownotvisible 290

7.4.9 doesnotincludemargininbodyoffset 292

7.5 事件测试(4项) 294

7.5.1 nocloneevent 294

7.5.2 submitbubbles、changebubbles、focusinbubbles 296

7.6 ajax测试(2项) 298

7.6.1 ajax 298

7.6.2 cors 300

7.7 总结 301

第四部分 功能模块

第8章 属性操作attributes 306

8.1 总体结构 307

8.2 jquery.attr( elem, name, value, pass ) 308

8.2.1 源码分析 308

8.2.2 boolhook 311

8.2.3 nodehook 313

8.2.4 jquery.attrhooks 314

8.2.5 小结 319

8.3 .attr( name, value ) 319

8.4 jquery.removeattr( elem, value ) 321

8.4.1 源码分析 321

8.4.2 小结 322

8.5 .removeattr( name ) 323

8.6 jquery.prop( elem, name, value ) 323

8.6.1 源码分析 323

8.6.2 jquery.prophooks 325

8.6.3 小结 326

8.7 .prop( name, value ) 327

8.8 .removeprop( name ) 327

8.9 .addclass( classname ) 328

8.9.1 源码分析 328

8.9.2 小结 330

8.10 .removeclass( [classname] ) 330

8.10.1 源码分析 331

8.10.2 小结 333

8.11 .toggleclass( [classname][, switch] ) 333

8.11.1 源码分析 334

8.11.2 小结 336

8.12 .hasclass( selector ) 336

8.12.1 源码分析 336

8.12.2 小结 337

8.13 .val( [value] ) 338

8.13.1 源码分析 338

8.13.2 jquery.valhooks 340

8.13.3 小结 343

8.14 总结 344

第9章 事件系统events 346

9.1 总体结构 346

9.2 实现原理 350

9.3 jquery 事件对象 353

9.3.1 构造函数jquery.event( src, props ) 355

9.3.2 原型对象jquery.event.prototype 357

9.3.3 事件属性修正方法jquery.event.fix( event ) 360

9.4 绑定事件 367

9.4.1 .on( events [, selector] [, data] , handler( eventobject ) ) 367

9.4.2 jquery.event.add( elem, types, handler, data, selector ) 370

9.5 移除事件 379

9.5.1 .off( events [, selector] [, handler( eventobject ) ] ) 379

9.5.2 jquery.event.remove( elem, types, handler, selector, mappedtypes ) 382

9.6 事件响应 388

9.6.1 主监听函数 388

9.6.2 jquery.event.dispatch( event ) 390

9.7 手动触发事件 396

9.7.1 .trigger( eventtype [, extraparameters] )、.triggerhandler( eventtype [, extraparameters] ) 396

9.7.2 jquery.event.trigger( event, data, elem, onlyhandlers ) 397

9.8 事件修正和模拟jquery.event.special 406

9.8.1 ready 408

9.8.2 load 408

9.8.3 focus、blur 409

9.8.4 beforeunload 409

9.8.5 mouseenter、mouseleave 410

9.8.6 submit 412

9.8.7 change 413

9.8.8 focusin、focusout 416

9.8.9 jquery.event.simulate( type, elem, event, bubble ) 417

9.9 事件便捷方法 418

9.10 组合方法 419

9.10.1 .toggle( handler( eventobject ), handler( eventobject ) [, handler( eventobject )] ) 419

9.10.2 .hover( handlerin( eventobject ) [, handlerout( eventobject )] ) 421

9.11 ready 事件 421

9.11.1 总体结构 421

9.11.2 .ready( handler ) 424

9.11.3 jquery.bindready() 424

9.11.4 jquery.holdready( hold ) 427

9.11.5 jquery.ready( wait ) 428

9.12 总结 430

第10章 dom遍历traversing 433

10.1 总体结构 434

10.2 遍历函数 435

10.3 工具函数 437

10.3.1 jquery.dir( elem, dir, until ) 437

10.3.2 jquery.nth( cur, result, dir, elem ) 439

10.3.3 jquery.sibling( n, elem ) 440

10.4 模板函数 441

10.5 总结 443

第11章 dom操作manipulation 444

11.1 总体结构 444

11.2 插入元素 445

11.2.1 核心方法.dommanip( args, table, callback ) 445

11.2.2 .append( content [, content] ) 451

11.2.3 .prepend( content [, content] ) 452

11.2.4 .before( content [, content] ) 452

11.2.5 .after( content [, content] ) 452

11.2.6 .appendto( target )、.prependto( target )、.insertbefore( target )、.insertafter( target ) 453

11.2.7 .html( [value] ) 454

11.2.8 .text( [text] ) 458

11.3 删除元素 459

11.3.1 .remove( selector, keepdata ) 459

11.3.2 .empty() 460

11.3.3 .detach( selector ) 460

11.4 复制元素 461

11.4.1 .clone( dataandevents, deepdataandevents ) 461

11.4.2 jquery.clone( elem, dataandevents, deepdataandevents ) 461

11.4.3 clonefixattributes( src, dest ) 465

11.5 替换元素 467

11.5.1 .replacewith( value ) 467

11.5.2 .replaceall( target ) 469

11.6 包裹元素 469

11.6.1 .wrapall( html ) 469

11.6.2 .wrapinner( html ) 470

11.6.3 .wrap( html ) 471

11.6.4 .unwrap() 471

11.7 总结 472

第12章 样式操作css 474

12.1 内联样式、计算样式 475

12.1.1 总体结构 475

12.1.2 .css( name, value ) 476

12.1.3 jquery.style( elem, name, value, extra ) 477

12.1.4 jquery.css( elem, name, extra ) 481

12.1.5 curcss( elem, name )、getcomputedstyle( elem, name )、currentstyle( elem, name ) 483

12.1.6 jquery.csshooks 486

12.2 坐标offset 492

12.2.1 总体结构 492

12.2.2 .offset( options ) 493

12.2.3 jquery.offset.setoffset( elem, options, i ) 498

12.2.4 jquery.offset.bodyoffset( body ) 500

12.2.5 .position() 501

12.2.6 .offsetparent() 502

12.2.7 .scrollleft( val )、.scrolltop( val ) 503

12.3 尺寸dimensions 504

12.3.1 总体结构 504

12.3.2 getwh( elem, name, extra ) 505

12.3.3 .innerheight()、.innerwidth() 508

12.3.4 .outerheight( margin )、.outerwidth( margin ) 509

12.3.5 .height( size )、.width( size ) 509

12.3.6 小结 513

12.4 总结 513

第13章 异步请求ajax 516

13.1 总体结构 517

13.2 jquery.ajax( url, options ) 519

13.3 前置过滤器、请求发送器的初始化和执行 540

13.3.1 初始化 540

13.3.2 执行 543

13.4 前置过滤器 545

13.4.1 json、jsonp 545

13.4.2 script 548

13.4.3 小结 549

13.5 请求发送器 549

13.5.1 script 549

13.5.2 xmlhttprequest 552

13.5.3 小结 560

13.6 数据转换器 561

13.6.1 初始化 561

13.6.2 执行 562

13.6.3 小结 566

13.7 ajax事件 567

13.8 便捷方法 568

13.8.1 jquery.get( url, data, callback, type )、jquery.post( url, data, callback, type ) 569

13.8.2 jquery.getjson( url, data, callback )、jquery.getscript( url, callback ) 569

13.8.3 .load( url, params, callback ) 570

13.9 工具方法 573

13.9.1 .serialize() 573

13.9.2 jquery.param( a, traditional ) 574

13.9.3 .serializearray() 577

13.10 总结 579

第14章 动画effects 582

14.1 总体结构 583

14.2 动画入口 586

14.2.1 .animate( prop, speed, easing, callback ) 586

14.2.2 jquery.speed( speed, easing, fn ) 588

14.2.3 doanimation() 590

14.2.4 jquery.fx( elem, options, prop ) 595

14.2.5 jquery.fx.prototype.show() 595

14.2.6 jquery.fx.prototype.hide() 596

14.2.7 小结 596

14.3 动画执行 597

14.3.1 jquery.fx.prototype.custom( from, to, unit ) 598

14.3.2 jquery.fx.tick() 599

14.3.3 jquery.fx.prototype.step( gotoend ) 600

14.3.4 jquery.easing 604

14.3.5 jquery.fx.prototype.update() 604

14.3.6 jquery.fx.step 605

14.4 停止动画.stop( type, clearqueue, gotoend ) 606

14.5 便捷方法 609

14.5.1 生成动画样式集genfx( type, num ) 609

14.5.2 显示隐藏.show/hide/toggle() 610

14.5.3 渐显渐隐.fadein/fadeout/fadeto/fadetoggle() 613

14.5.4 滑入滑出.slidedown/slidup/slidetoggle() 614

14.6 总结 615

本图书信息来源:互动出版

《jQuery技术内幕:深入解析jQuery架构设计与实现原理》的更多相关文章

  1. 简单物联网:外网访问内网路由器下树莓派Flask服务器

    最近做一个小东西,大概过程就是想在教室,宿舍控制实验室的一些设备. 已经在树莓上搭了一个轻量的flask服务器,在实验室的路由器下,任何设备都是可以访问的:但是有一些限制条件,比如我想在宿舍控制我种花 ...

  2. 利用ssh反向代理以及autossh实现从外网连接内网服务器

    前言 最近遇到这样一个问题,我在实验室架设了一台服务器,给师弟或者小伙伴练习Linux用,然后平时在实验室这边直接连接是没有问题的,都是内网嘛.但是回到宿舍问题出来了,使用校园网的童鞋还是能连接上,使 ...

  3. 外网访问内网Docker容器

    外网访问内网Docker容器 本地安装了Docker容器,只能在局域网内访问,怎样从外网也能访问本地Docker容器? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Docker容器 ...

  4. 外网访问内网SpringBoot

    外网访问内网SpringBoot 本地安装了SpringBoot,只能在局域网内访问,怎样从外网也能访问本地SpringBoot? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装Java 1 ...

  5. 外网访问内网Elasticsearch WEB

    外网访问内网Elasticsearch WEB 本地安装了Elasticsearch,只能在局域网内访问其WEB,怎样从外网也能访问本地Elasticsearch? 本文将介绍具体的实现步骤. 1. ...

  6. 怎样从外网访问内网Rails

    外网访问内网Rails 本地安装了Rails,只能在局域网内访问,怎样从外网也能访问本地Rails? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Rails 默认安装的Rails端口 ...

  7. 怎样从外网访问内网Memcached数据库

    外网访问内网Memcached数据库 本地安装了Memcached数据库,只能在局域网内访问,怎样从外网也能访问本地Memcached数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装 ...

  8. 怎样从外网访问内网CouchDB数据库

    外网访问内网CouchDB数据库 本地安装了CouchDB数据库,只能在局域网内访问,怎样从外网也能访问本地CouchDB数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Cou ...

  9. 怎样从外网访问内网DB2数据库

    外网访问内网DB2数据库 本地安装了DB2数据库,只能在局域网内访问,怎样从外网也能访问本地DB2数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动DB2数据库 默认安装的DB2 ...

  10. 怎样从外网访问内网OpenLDAP数据库

    外网访问内网OpenLDAP数据库 本地安装了OpenLDAP数据库,只能在局域网内访问,怎样从外网也能访问本地OpenLDAP数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动 ...

随机推荐

  1. WP SMTP插件为啥我一直设置的不对?

    我也是摸索好久才搞定的,如果你是万网空间先去修改一下参数在万网后台设置PHP.ini参数设置,因为万网阿里云免费虚拟主机禁用了WordPress默认使用的PHP mail()发信函数,而 stream ...

  2. 常用的scrapy setting

    原文请参考    Scrapy 爬虫入门教程十三 Settings(设置), 讲的很详细 官网参考  Settings 设置 Scrapy 设置允许您自定义所有 Scrapy 组件的行为,包括核心,扩 ...

  3. spring boot 笔记

    1.不能访问非启动类中的@RequestMapping 路径: 启动类注解 1.@Controller @EnableAutoConfiguration @ComponentScan 或 2.@Spr ...

  4. bzoj 1854 并查集 + 贪心

    思路:这个题的并查集用的好NB啊, 我们把伤害看成图上的点,武器作为边,对于一个联通块来说, 如果是一棵大小为k的树,那么这个联通块里面有k - 1个伤害能被取到,如果图上有环那么k个值都能 取到,对 ...

  5. 【.NET】学习SQLite(1)

    前沿 SQLite,是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存 ...

  6. ArrayBuffer对象、TypedArray视图和DataView视图

    转:http://es6.ruanyifeng.com/#docs/arraybuffer ArrayBuffer ArrayBuffer 对象 TypedArray 视图 复合视图 DataView ...

  7. (16) go 面向对象

    一.封装 二.继承 1. 2. 3. 4. 5 6. 7.多重继承 三.接口

  8. RxSwift 系列(一)

    为什么使用RxSwift? 我们编写的代码绝大多数都涉及对外部事件的响应.当用户点击操作时,我们需要编写一个@IBAction事件来响应.我们需要观察通知,以检测键盘何时改变位置.当网络请求响应数据时 ...

  9. python中间件

    django 中的中间件(middleware),在django中,中间件其实就是一个类,在请求到来和结束后,django会根据自己的规则在合适的时机执行中间件中相应的方法. 1.中间件的方法 pro ...

  10. FFTW3学习笔记1:VS2015下配置FFTW3(快速傅里叶变换)库

    一.FFTW简介 FFTW ( the Faster Fourier Transform in the West) 是一个快速计算离散傅里叶变换的标准C语言程序集,其由MIT的M.Frigo 和S. ...