검색결과 리스트
글
결국 arguments의 length 속성을 이용한다.
val: function( value ) {
var hooks, ret, isFunction,
elem = this[0];
if ( !arguments.length ) {
if ( elem ) {
hooks = jQuery.valHooks[ elem.type ] || jQuery.valHooks[ elem.nodeName.toLowerCase() ];
if ( hooks && "get" in hooks && (ret = hooks.get( elem, "value" )) !== undefined ) {
return ret;
}
ret = elem.value;
return typeof ret === "string" ?
// handle most common string cases
ret.replace(rreturn, "") :
// handle cases where value is null/undef or number
ret == null ? "" : ret;
}
return;
}
isFunction = jQuery.isFunction( value );
return this.each(function( i ) {
var self = jQuery(this), val;
if ( this.nodeType !== 1 ) {
return;
}
if ( isFunction ) {
val = value.call( this, i, self.val() );
} else {
val = value;
}
// Treat null/undefined as ""; convert numbers to string
if ( val == null ) {
val = "";
} else if ( typeof val === "number" ) {
val += "";
} else if ( jQuery.isArray( val ) ) {
val = jQuery.map(val, function ( value ) {
return value == null ? "" : value + "";
});
}
hooks = jQuery.valHooks[ this.type ] || jQuery.valHooks[ this.nodeName.toLowerCase() ];
// If set returns undefined, fall back to normal setting
if ( !hooks || !("set" in hooks) || hooks.set( this, val, "value" ) === undefined ) {
this.value = val;
}
});
}
'JavaScript > jQuery' 카테고리의 다른 글
[jQuery] jQuery의 핵심 Selector Sizzle (0) | 2012.11.07 |
---|---|
[jQuery] jQuery 구조 분석 (0) | 2012.11.07 |
[jQuery] PlugIn 만들기 (0) | 2012.08.08 |
[jQuery] .attr("disabled") .attr("readonly") 리턴값 (0) | 2012.08.01 |
[jQuery] .each $.each 순회중 continue, break 하기 (0) | 2012.07.26 |
RECENT COMMENT