<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>
jquery.access源码分析(2.0.3)
猜你喜欢
转载自blog.csdn.net/rose999ying/article/details/86492360
今日推荐
周排行