jquery.access源码分析(2.0.3)

<script>
			function access( elems, fn, key, value, chainable, emptyGet, raw ) {
				/*
				*@param elems ==> 要操作的元素,可能是一个集合数组,
				*@param fn  ==> 回调,区分具体是操作,比如使用的是attr()方法和css()方法具体操作是不同的,这种情况都是放到回调当中去操作
				*@param key ==> 是指各回调函数传入的参数,比如css("background", "red")==>key是指css()这个回调函数中的background,key有可能是一个对象
				*@param value ==> 是指各个回调函数传入的参数,比如css("background", "red")==>key是指css()这个回调函数中的background,value 是指red
				*@param chainable ==> 如果这个值为真的 ==> 设置,如果这个值为假==> 获取;它是用来控制是设置还是获取的
				*@param emptyGet ==>
				*@param row ==> 标记value是否为函数的情况
				*/
				var i = 0,
					length = elems.length,
					bulk = key == null;//key值跟null比较,看key是否有值,如果有,则bulk为false,如果key没有值,则bulk为true

				// Sets many values
				if ( jQuery.type( key ) === "object" ) {
					chainable = true;
					for ( i in key ) {
						jQuery.access( elems, fn, i, key[i], true, emptyGet, raw );
					}

				// Sets one value
				} else if ( value !== undefined ) {
					chainable = true;

					if ( !jQuery.isFunction( value ) ) {//如果value不是函数,则row为正
						raw = true;
					}

					if ( bulk ) {
						// Bulk operations run against the entire set
						if ( raw ) {
							fn.call( elems, value );//value 是字符串的情况
							fn = null;

						// ...except when executing function values
						} else {//value 不是字符串的情况
							bulk = fn;
							fn = function( elem, key, value ) {
								return bulk.call( jQuery( elem ), value );
							};
						}
					}

					if ( fn ) {
						for ( ; i < length; i++ ) {
							fn( elems[i], key, raw ? value : value.call( elems[i], i, fn( elems[i], key ) ) );
						}
					}
				}

				return chainable ?
					elems :

					// Gets
					bulk ?
						fn.call( elems ) :
						length ? fn( elems[0], key ) : emptyGet;//emptyGet 是 undefined
			}
		</script>

猜你喜欢

转载自blog.csdn.net/rose999ying/article/details/86492360
今日推荐