Heim >Web-Frontend >js-Tutorial >jQuery 源码分析笔记(6) jQuery.data_jquery
data部分的代码从1381行开始。最开始的几行关键代码:
<code>// data未定义,说明当前调用是查询数据,但是对象没有任何数据,直接返回 <br>if((!id || (pvt && id && !cache[id][internalKey])) && getByName && data === undefined) { <br>return; <br>} <br>if(!id) { <br>if(isNode) { <br>// 用uuid种子递增分配唯一ID,只有DOM元素需要。因为需要存在全局cache中 <br>elem[jQuery.expando] = id = ++jQuery.uuid; <br>} else { <br>id = jQuery.expando; <br>} <br>} <br>// 清空原来的值 <br>if(!cache[id]) { <br>cache[id] = {}; <br>if(!isNode) { <br>cache[id].toJSON = jQuery.noop; <br>} <br>} <br>// 用extend扩展cache,增加一个属性,用来保存数据 <br>if(typeof name === "object" || typeof name === "function") { <br>if(pvt) { <br>cache[id][internalKey] = jQuery.expand(cache[id][internalKey], name); <br>} else { <br>cache[id] = jQuery.extend(cache[id], name); <br>} <br>} <br>thisCache = cahce[id]; <br>// 避免Key冲突 <br>if(pvt) { <br>if(!thisCache[internalKey]) { <br>thisCahce[internalKey] = {}; <br>} <br>thisCache = thisCache[internalKey]; <br>} <br>if(data !== undefined) { <br>thisCache[jQuery.camelCase(name)] = data; <br>} <br>return getByName ? thisCache[jQuery.camelCase(name)] : thisCache; <br>} <br>removeData: function( elem, name, pvt ) { // 前面部分与data类似 // ... // 部分浏览器不支持在Element上进行delete操作,在jQuery.support中检查过这个浏览器特性。 // 如果delete失败的话,就先设置成null。 if ( jQuery.support.deleteExpando || cache != window ) { delete cache[ id ]; } else { cache[ id ] = null; } <br><pre class="brush:;gutter:true;"><code>var internalCache = cache[ id ][ internalKey ]; <br>// 如果还有数据,就清空一次再设置,增加性能 <br>if ( internalCache ) { <br>cache[ id ] = {}; <br>cache[ id ][ internalKey ] = internalCache; <br>// 已经没有任何数据了,就全部删除 <br>} else if ( isNode ) { <br>// 如果支持delete,就删除。 <br>// IE使用removeAttribute,所以尝试一次。再失败就只能设置为null了。 <br>if ( jQuery.support.deleteExpando ) { <br>delete elem[ jQuery.expando ]; <br>} else if ( elem.removeAttribute ) { <br>elem.removeAttribute( jQuery.expando ); <br>} else { <br>elem[ jQuery.expando ] = null; <br>} <br>} <br>} <br></code>