新書推薦:
《
元好问与他的时代(中华学术译丛)
》
售價:HK$
87.4
《
汽车传感器结构·原理·检测·维修
》
售價:HK$
109.8
《
怪谈百物语:不能开的门(“日本文学史上的奇迹”宫部美雪重要代表作!日本妖怪物语集大成之作,系列累销突破200万册!)
》
售價:HK$
65.0
《
罗马政治观念中的自由
》
售價:HK$
50.4
《
中国王朝内争实录:宠位厮杀
》
售價:HK$
61.6
《
凡事发生皆有利于我(这是一本读了之后会让人运气变好的书”治愈无数读者的心理自助经典)
》
售價:HK$
44.6
《
未来特工局
》
售價:HK$
55.8
《
高术莫用(十周年纪念版 逝去的武林续篇 薛颠传世之作 武学尊师李仲轩家世 凸显京津地区一支世家的百年沉浮)
》
售價:HK$
54.9
|
編輯推薦: |
阿里巴巴资深前端开发工程师撰写,透视jQuery 17个模块的架构设计理念和内部实现原理 全面系统地解读最新版本jQuery源码,帮助读者掌握其中的实现技巧和技术精髓
|
內容簡介: |
本书由阿里巴巴资深前端开发工程师撰写,从源代码角度全面而系统地解读了jQuery的17个模块的架构设计理念和内部实现原理,旨在帮助读者参透jQuery中的实现技巧和技术精髓,同时本书也对广大开发者如何通过阅读源代码来提升编码能力和软件架构能力提供了指导。
本书首先通过“总体架构”梳理了各个模块的分类、功能和依赖关系,让大家对jQuery的工作原理有大致的印象;进而通过“构造jQuery对象”章节分析了构造函数jQuery的各种用法和内部构造过程;接着详细分析了底层支持模块的源码实现,包括:选择器Sizzle、异步队列Deferred、数据缓存Data、队列Queue、浏览器功能测试Support;最后详细分析了功能模块的源码实现,包括:属性操作Attributes、事件系统Events、DOM遍历Traversing、DOM操作Manipulation、样式操作CSS、异步请求Ajax、动画Effects。
本书在分析每个模块时均采用由浅入深的方式,先概述功能、用法、结构和实现原理,然后介绍关键步骤和分析源码实现。让读者不仅知其然,而且知其所以然。事实上,本书的根本价值在于传达一种通过阅读源码快速成长的方式。无论是前端新人,还是经验丰富的老手,只要是对JavaScript感兴趣的开发人员,都会从本书中受益。
|
關於作者: |
高云 阿里巴巴资深前端开发工程师(花名墨智),拥有丰富的前端开发经验,擅长 HTML5、CSS、JavaScript 等 Web 开发技术和 Java 技术,对 JavaScript 相关技术的应用与实现原理有深入研究和独到见解。个人博客 http:nuysoft.com,开源作品有
|
目錄:
|
前言
第一部分 总体架构
第1章 总体架构
1.1 设计理念
1.2 总体架构
1.3 自调用匿名函数
1.4 总结
第二部分 构造jQuery对象
第2章 构造jQuery对象
2.1 构造函数jQuery
2.1.1 jQuery selector [, context]
2.1.2 jQuery html [, ownerDocument] 、jQuery html, props
2.1.3 jQuery element 、jQuery elementArray
2.1.4 jQuery object
2.1.5 jQuery callback
2.1.6 jQuery jQuery object
2.1.7 jQuery
2.2 总体结构
2.3 jQuery.fn.init selector, context, rootjQuery
2.3.1 12个分支
2.3.2 源码分析
2.3.3 小结
2.4 jQuery.buildFragment args, nodes, scripts
2.4.1 实现原理
2.4.2 源码分析
2.4.3 小结
2.5 jQuery.clean elems, context, fragment, scripts
2.5.1 实现原理
2.5.2 源码分析
2.5.3 小结
2.6 jQuery.extend、jQuery.fn.extend
2.6.1 如何使用
2.6.2 源码分析
2.7 原型属性和方法
2.7.1 .selector、.jquery、.length、.size
2.7.2 .toArray、.get [index]
2.7.3 .each functionindex, Element 、jQuery.each collection, callback indexInArray, valueOfElement
2.7.4 .map callbackindex, domElement 、jQuery.map arrayOrObject, callbackvalue, indexOrKey
2.7.5 .pushStack elements, name, arguments
2.7.6 .end
2.7.7 .eq index 、.first、.last、.slice start [, end]
2.7.8 .push value, ... 、.sort [orderfunc] 、.splice start,deleteCount, value, ...
2.7.9 小结
2.8 静态属性和方法
2.8.1 jQuery.noConflict [removeAll]
2.8.2 类型检测:jQuery.isFunction obj 、jQuery.isArray obj 、jQuery.isWindow obj 、jQuery.isNumeric value 、jQuery.type obj 、jQuery.isPlainObject object 、jQuery.isEmptyObject object
2.8.3 解析JSON和XML:jQuery.parseJSON data 、jQuery.parseXML data
2.8.4 jQuery.globalEval code
2.8.5 jQuery.camelCase string
2.8.6 jQuery.nodeName elem, name
2.8.7 jQuery.trim str
2.8.8 数组操作方法:jQuery.makeArray obj 、jQuery.inArray value, array [, fromIndex] 、jQuery.merge first, second 、jQuery.grep array, functionelementOfArray, indexInArray [, invert]
2.8.9 jQuery.guid、jQuery.proxy function, context
2.8.10 jQuery.access elems, key, value, exec, fn elem, key, value , pass
2.8.11 jQuery.error message 、jQuery.noop、jQuery.now
2.8.12 浏览器嗅探:jQuery.uaMatch ua 、jQuery.browser
2.8.13 小结
2.9 总结
第三部分 底层支持模块
第3章 选择器Sizzle
3.1 总体结构
3.2 选择器表达式
3.3 设计思路
3.4 Sizzle selector, context, results, seed
3.5 正则chunker
3.6 Sizzle.find expr, context, isXML
3.7 Sizzle.filter expr, set, inplace, not
3.8 Sizzle.selectors.relative
3.8.1 "+"
3.8.2 ""
3.8.3 ""
3.8.4 "~"
3.8.5 dirCheck dir, cur, doneName, checkSet, nodeCheck, isXML
3.8.6 dirNodeCheck dir, cur, doneName, checkSet, nodeCheck, isXML
3.9 Sizzle.selectors
3.9.1 Sizzle.selectors.order
3.9.2 Sizzle.selectors.matchleftMatch
3.9.3 Sizzle.selectors.find
3.9.4 Sizzle.selectors.preFilter
3.9.5 Sizzle.selectors.filters
3.9.6 Sizzle.selectors.setFilters
3.9.7 Sizzle.selectors.filter
3.10 工具方法
3.10.1 Sizzle.uniqueSort results
3.10.2 sortOrder a, b
3.10.3 Sizzle.contains a, b
3.10.4 Sizzle.error msg
3.10.5 Sizzle.getText elem
3.11 便捷方法
3.11.1 Sizzle.matches expr, set
3.11.2 Sizzle.matchesSelector node, expr
3.12 jQuery扩展
3.12.1 暴露Sizzle给jQuery
3.12.2 .find selector
3.12.3 .has target
3.12.4 .not selector 、.filter selector
3.12.5 .is selector
3.12.6 .closest selectors, context
3.12.7 .index elem
3.12.8 .add selector, context
3.12.9 jQuery.filter expr, elems, not
3.12.10 :animated
3.12.11 hidden、:visible
3.13 总结
第4章 异步队列Deferred Object
4.1 jQuery.Callbacks flags
4.1.1 实现原理和总体结构
4.1.2 源码分析
4.1.3 小结
4.2 jQuery.Deferred func
4.2.1 实现原理和总体结构
4.2.2 源码分析
4.2.3 小结
4.3 jQuery.when deferreds
4.3.1 实现原理
4.3.2 源码分析
4.4 异步队列在jQuery中的应用
4.5 总结
第5章 数据缓存Data
5.1 实现原理
5.1.1 为DOM元素附加数据
5.1.2 为JavaScript对象附加数据
5.2 总体结构
5.3 jQuery.acceptData elem
5.4 jQuery.data elem, name, data, pvt 、jQuery._data elem, name, data, pvt
5.4.1 如何使用
5.4.2 源码分析
5.4.3 jQuery._data elem, name, data
5.4.4 小结
5.5 .data key,value
5.5.1 如何使用
5.5.2 源码分析
5.5.3 小结
5.6 jQuery.removeData elem,name,pvt 、.removeData key
5.6.1 如何使用
5.6.2 源码分析
5.6.3 小结
5.7 .removeData key
5.8 jQuery.cleanData elems
5.8.1 应用场景
5.8.2 源码分析
5.8.3 小结
5.9 jQuery.hasData elem
5.10 总结
第6章 队列Queue
6.1 如何使用
6.1.1 Ajax队列
6.1.2 动画队列+ Ajax队列
6.1.3 基于JavaScript对象
6.2 实现原理
6.3 总体结构
6.4 jQuery.queue elem,type,data
6.5 jQuery.dequeue elem,type
6.6 .queue type,data
6.7 .dequeue type
6.8 .delay time,type
6.9 .clearQueue type
6.10 jQuery._mark elem,type 、jQuery._unmark force,elem,type
6.11 .promise type,object
6.11.1 如何使用
6.11.2 实现原理
6.11.3 源码分析
6.11.4 handleQueueMarkDefer elem,type,src
6.12 总结
第7章 浏览器功能测试Support
7.1 总体结构
7.2 DOM测试(15项)
7.2.1 leadingWhitespace
7.2.2 tbody
7.2.3 htmlSerialize
7.2.4 hrefNormalized
7.2.5 checkOn
7.2.6 noCloneChecked
7.2.7 optSelected
7.2.8 optDisabled
7.2.9 getSetAttribute
7.2.10 deleteExpando
7.2.11 enctype
7.2.12 html5Clone
7.2.13 radioValue
7.2.14 checkClone
7.2.15 appendChecked
7.3 样式测试(3项)
7.3.1 style
7.3.2 opacity
7.3.3 cssFloat
7.4 盒模型测试(10项)
7.4.1 reliableMarginRight
7.4.2 reliableHiddenOffsets
7.4.3 boxModel
7.4.4 inlineBlockNeedsLayout
7.4.5 shrinkWrapBlocks
7.4.6 doesNotAddBorder、doesAddBorderForTableAndCells
7.4.7 fixedPosition
7.4.8 subtractsBorderForOverflowNotVisible
7.4.9 doesNotIncludeMarginInBodyOffset
7.5 事件测试(4项)
7.5.1 noCloneEvent
7.5.2 submitBubbles、changeBubbles、focusinBubbles
7.6 Ajax测试(2项)
7.6.1 ajax
7.6.2 cors
7.7 总结
第四部分 功能模块
第8章 属性操作Attributes
8.1 总体结构
8.2 jQuery.attr elem, name, value, pass
8.2.1 源码分析
8.2.2 boolHook
8.2.3 nodeHook
8.2.4 jQuery.attrHooks
8.2.5 小结
8.3 .attr name, value
8.4 jQuery.removeAttr elem, value
8.4.1 源码分析
8.4.2 小结
8.5 .removeAttr name
8.6 jQuery.prop elem, name, value
8.6.1 源码分析
8.6.2 jQuery.propHooks
8.6.3 小结
8.7 .prop name, value
8.8 .removeProp name
8.9 .addClass className
8.9.1 源码分析
8.9.2 小结
8.10 .removeClass [className]
8.10.1 源码分析
8.10.2 小结
8.11 .toggleClass [className][, switch]
8.11.1 源码分析
8.11.2 小结
8.12 .hasClass selector
8.12.1 源码分析
8.12.2 小结
8.13 .val [value]
8.13.1 源码分析
8.13.2 jQuery.valHooks
8.13.3 小结
8.14 总结
第9章 事件系统Events
9.1 总体结构
9.2 实现原理
9.3 jQuery 事件对象
9.3.1 构造函数jQuery.Event src, props
9.3.2 原型对象jQuery.Event.prototype
9.3.3 事件属性修正方法jQuery.event.fix event
9.4 绑定事件
9.4.1 .on events [, selector] [, data] , handler eventObject
9.4.2 jQuery.event.add elem, types, handler, data, selector
9.5 移除事件
9.5.1 .off events [, selector] [, handler eventObject ]
9.5.2 jQuery.event.remove elem, types, handler, selector, mappedTypes
9.6 事件响应
9.6.1 主监听函数
9.6.2 jQuery.event.dispatch event
9.7 手动触发事件
9.7.1 .trigger eventType [, extraParameters] 、.triggerHandler eventType [, extraParameters]
9.7.2 jQuery.event.trigger event, data, elem, onlyHandlers
9.8 事件修正和模拟jQuery.event.special
9.8.1 ready
9.8.2 load
9.8.3 focus、blur
9.8.4 beforeunload
9.8.5 mouseenter、mouseleave
9.8.6 submit
9.8.7 change
9.8.8 focusin、focusout
9.8.9 jQuery.event.simulate type, elem, event, bubble
9.9 事件便捷方法
9.10 组合方法
9.10.1 .toggle handler eventObject , handler eventObject [, handler eventObject ]
9.10.2 .hover handlerIn eventObject [, handlerOut eventObject ]
9.11 ready 事件
9.11.1 总体结构
9.11.2 .ready handler
9.11.3 jQuery.bindReady
9.11.4 jQuery.holdReady hold
9.11.5 jQuery.ready wait
9.12 总结
第10章 DOM遍历Traversing
10.1 总体结构
10.2 遍历函数
10.3 工具函数
10.3.1 jQuery.dir elem, dir, until
10.3.2 jQuery.nth cur, result, dir, elem
10.3.3 jQuery.sibling n, elem
10.4 模板函数
10.5 总结
第11章 DOM操作Manipulation
11.1 总体结构
11.2 插入元素
11.2.1 核心方法.domManip args, table, callback
11.2.2 .append content [, content]
11.2.3 .prepend content [, content]
11.2.4 .before content [, content]
11.2.5 .after content [, content]
11.2.6 .appendTo target 、.prependTo target 、.insertBefore target 、.insertAfter target
11.2.7 .html [value]
11.2.8 .text [text]
11.3 删除元素
11.3.1 .remove selector, keepData
11.3.2 .empty
11.3.3 .detach selector
11.4 复制元素
11.4.1 .clone dataAndEvents, deepDataAndEvents
11.4.2 jQuery.clone elem, dataAndEvents, deepDataAndEvents
11.4.3 cloneFixAttributes src, dest
11.5 替换元素
11.5.1 .replaceWith value
11.5.2 .replaceAll target
11.6 包裹元素
11.6.1 .wrapAll html
11.6.2 .wrapInner html
11.6.3 .wrap html
11.6.4 .unwrap
11.7 总结
第12章 样式操作CSS
12.1 内联样式、计算样式
12.1.1 总体结构
12.1.2 .css name, value
12.1.3 jQuery.style elem, name, value, extra
12.1.4 jQuery.css elem, name, extra
12.1.5 curCSS elem, name 、getComputedStyle elem, name 、currentStyle elem, name
12.1.6 jQuery.cssHooks
12.2 坐标Offset
12.2.1 总体结构
12.2.2 .offset options
12.2.3 jQuery.offset.setOffset elem, options, i
12.2.4 jQuery.offset.bodyOffset body
12.2.5 .position
12.2.6 .offsetParent
12.2.7 .scrollLeft val 、.scrollTop val
12.3 尺寸Dimensions
12.3.1 总体结构
12.3.2 getWH elem, name, extra
12.3.3 .innerHeight、.innerWidth
12.3.4 .outerHeight margin 、.outerWidth margin
12.3.5 .height size 、.width size
12.3.6 小结
12.4 总结
第13章 异步请求Ajax
13.1 总体结构
13.2 jQuery.ajax url, options
13.3 前置过滤器、请求发送器的初始化和执行
13.3.1 初始化
13.3.2 执行
13.4 前置过滤器
13.4.1 json、jsonp
13.4.2 script
13.4.3 小结
13.5 请求发送器
13.5.1 script
13.5.2 XMLHttpRequest
13.5.3 小结
13.6 数据转换器
13.6.1 初始化
13.6.2 执行
13.6.3 小结
13.7 Ajax事件
13.8 便捷方法
13.8.1 jQuery.get url, data, callback, type 、jQuery.post url, data, callback, type
13.8.2 jQuery.getJSON url, data, callback 、jQuery.getScript url, callback
13.8.3 .load url, params, callback
13.9 工具方法
13.9.1 .serialize
13.9.2 jQuery.param a, traditional
13.9.3 .serializeArray
13.10 总结
第14章 动画Effects
14.1 总体结构
14.2 动画入口
14.2.1 .animate prop, speed, easing, callback
14.2.2 jQuery.speed speed, easing, fn
14.2.3 doAnimation
14.2.4 jQuery.fx elem, options, prop
14.2.5 jQuery.fx.prototype.show
14.2.6 jQuery.fx.prototype.hide
14.2.7 小结
14.3 动画执行
14.3.1 jQuery.fx.prototype.custom from, to, unit
14.3.2 jQuery.fx.tick
14.3.3 jQuery.fx.prototype.step gotoEnd
14.3.4 jQuery.easing
14.3.5 jQuery.fx.prototype.update
14.3.6 jQuery.fx.step
14.4 停止动画.stop type, clearQueue, gotoEnd
14.5 便捷方法
14.5.1 生成动画样式集genFx type, num
14.5.2 显示隐藏.showhidetoggle
14.5.3 渐显渐隐.fadeInfadeOutfadeTofadeToggle
14.5.4 滑入滑出.slideDownslidUpslideToggle
14.6 总结
|
內容試閱:
|
第一部分
总 体 架 构
第1章 总体架构
第1章
总 体 架 构
1.1 设计理念
jQuery是一款革命性的JavaScript库,秉承着“以用为本”的设计理念,倡导“写更少的代码,做更多的事”(write less, do more),极大地提升了JavaScript开发体验。
jQuery的核心特性可以总结为:
兼容主流浏览器,支持IE 6.0+、Chrome、Firefox 3.6+、Safari 5.0+、Opera等。
具有独特的链式语法和短小清晰的多功能接口。
具有高效灵活的CSS选择器,并且可对CSS选择器进行扩展。
拥有便捷的插件扩展机制和丰富的插件。
1.2 总体架构
jQuery的模块可以分为3部分:入口模块、底层支持模块和功能模块,如图1-1所示,图中还展示了模块之间的主要依赖关系。
来看看图1-1中各个模块的功能和依赖关系。
在构造jQuery对象模块中,如果在调用构造函数jQuery创建jQuery对象时传入了选择器表达式,则会调用选择器Sizzle遍历文档,查找与之匹配的DOM元素,并创建一个包含了这些DOM元素引用的jQuery对象。
选择器Sizzle是一款纯JavaScript实现的CSS选择器引擎,用于查找与选择器表达式匹配的元素集合。
工具方法模块提供了一些编程辅助方法,用于简化对jQuery对象、DOM元素、数组、对象、字符串等的操作,例如,jQuery.each、.each、jQuery.map、.map等,其他所有的模块都会用到工具方法模块。
图1-1 jQuery的模块分类和主要依赖关系
浏览器功能测试模块提供了针对不同浏览器功能和bug的测试结果,其他模块则基于这些测试结果来解决浏览器之间的兼容性问题。
在底层支持模块中,回调函数列表模块用于增强对回调函数的管理,支持添加、移除、触发、锁定、禁用回调函数等功能;异步队列模块用于解耦异步任务和回调函数,它在回调函数列表的基础上为回调函数增加了状态,并提供了多个回调函数列表,支持传播任意同步或异步回调函数的成功或失败状态;数据缓存模块用于为DOM元素和JavaScript对象附加任意类型的数据;队列模块用于管理一组函数,支持函数的入队和出队操作,并确保函数按顺序执行,它基于数据缓存模块实现。
在功能模块中,事件系统提供了统一的事件绑定、响应、手动触发和移除机制,它并没有将事件直接绑定到DOM元素上,而是基于数据缓存模块来管理事件;Ajax模块允许从服务器上加载数据,而不用刷新页面,它基于异步队列模块来管理和触发回调函数;动画模块用于向网页中添加动画效果,它基于队列模块来管理和执行动画函数;属性操作模块用于对HTML属性和DOM属性进行读取、设置和移除操作;DOM遍历模块用于在DOM树中遍历父元素、子元素和兄弟元素;DOM操作模块用于插入、移除、复制和替换DOM元素;样式操作模块用于获取计算样式或设置内联样式;坐标模块用于读取或设置DOM元素的文档坐标;尺寸模块用于获取DOM元素的高度和宽度。
|
|