1 var X_Node_Attr_noValue = {
\r
16 X_Node_Attr_renameForDOM = {
\r
17 'class' : 'className',
\r
18 accesskey : 'accessKey',
\r
19 'accept-charset' : 'acceptCharset',
\r
20 bgcolor : 'bgColor',
\r
21 cellpadding : 'cellPadding',
\r
22 cellspacing : 'cellSpacing',
\r
25 codebase : 'codeBase',
\r
26 codetype : 'codeType',
\r
27 colspan : 'colSpan',
\r
28 datetime : 'dateTime',
\r
30 frameborder : 'frameBorder',
\r
31 'http-equiv' : 'httpEquiv',
\r
33 longdesc : 'longDesc',
\r
34 maxlength : 'maxLength',
\r
36 readonly : 'readOnly',
\r
37 rowspan : 'rowSpan',
\r
38 tabindex : 'tabIndex',
\r
40 valuetype : 'valueType',
\r
41 checked : 'defaultChecked'
\r
44 X_Node_Attr_HAS_VALUE = {
\r
50 PARAM : true // FlashVars が flash 側から書き換えられるケースがある??
\r
53 // <input type=button,hidden,submit,reset,radio,checkbox> の場合、value の値はユーザーで変えることはない
\r
54 // <input type=text,password,file> はユーザーによって常に変更される HTML5 ではこれにさらにいろいろ加わる
\r
55 X_Node_Attr_STATIC_VALUE_TYPES = {
\r
64 X_Node_Attr_renameForTag = {};
\r
65 // http://nanto.asablo.jp/blog/2005/10/29/123294
\r
66 // checked -> defaultChecked
\r
67 // 動的に生成した input 要素を文書ツリーに挿入する前に設定した checked 属性は反映されず、defaultChecked だと反映される
\r
69 function X_Node_Attr_objToAttrText( that ){
\r
70 var obj = that._attrs,
\r
71 noValue = X_Node_Attr_noValue,
\r
73 plain = X_EMPTY_OBJECT,
\r
76 that._flags &= ~X_Node_State.OLD_ATTRTEXT;
\r
78 if( !obj ){ // Opera7
\r
79 delete that._attrText;
\r
83 if( plain[ k ] ) continue;
\r
85 if( k === 'value' ){
\r
86 v = v.split( '"' ).join( '"' ).split( '>' ).join( '>' ).split( '<' ).join( '<' );
\r
88 attrs[ ++n ] = noValue[ k ] ? k : [ k, '="', v, '"' ].join( '' );
\r
91 return that._attrText = attrs.join( ' ' );
\r
93 delete that._attrText;
\r
97 (function( renameForDOM, renameForTag ){
\r
99 for( k in renameForDOM ){
\r
100 //if( X_EMPTY_OBJECT[ k ] ) continue;
\r
101 renameForTag[ renameForDOM[ k ] ] = k;
\r
103 })( X_Node_Attr_renameForDOM, X_Node_Attr_renameForTag );
\r
107 /* --------------------------------------
\r
110 * http://nanto.asablo.jp/blog/2005/10/29/123294
\r
111 * className, onclick等 はここで設定しない
\r
114 Node.prototype.attr = function( nameOrObj /* v */ ){
\r
115 var attrs = this._attrs, newAttrs, f, k, elm, v;
\r
117 if( !this._tag ) return this;
\r
119 if( nameOrObj && X.Type.isObject( nameOrObj ) ){
\r
120 attrs || ( attrs = this._attrs = {} );
\r
121 newAttrs = this._newAttrs || ( this._newAttrs = {} );
\r
123 for( k in nameOrObj ){
\r
124 //if( X_EMPTY_OBJECT[ k ] ) continue;
\r
125 if( X_Node_Attr_setAttr( this, attrs, newAttrs, k, nameOrObj[ k ] ) === true ) f = true;
\r
128 delete this._attrText;
\r
129 this._flags |= X_Node_State.DIRTY_ATTR | X_Node_State.OLD_ATTRTEXT;
\r
130 this._flags & X_Node_State.IN_TREE && X_Node_reserveUpdate();
\r
134 if( 1 < arguments.length ){
\r
136 if( X_Node_Attr_setAttr( this, attrs || ( this._attrs = {} ), this._newAttrs || ( this._newAttrs = {} ), nameOrObj, arguments[ 1 ] ) === true ){
\r
137 delete this._attrText;
\r
138 this._flags |= X_Node_State.DIRTY_ATTR | X_Node_State.OLD_ATTRTEXT;
\r
139 this._flags & X_Node_State.IN_TREE && X_Node_reserveUpdate();
\r
143 if( typeof nameOrObj === 'string' ){
\r
145 switch( nameOrObj ){
\r
150 return this._className;
\r
156 return this.cssText();
\r
159 // kquery.js : safariのバグ対策
\r
160 // if ($.browser.safari && key === "selected" && tmp) tmp.selectedIndex;
\r
161 // 親ノードの selectedIndex の getter を呼んでおくと値が正しくなる、ということ?( by itozyun )
\r
162 if( X_UA.WebKit ) this._rawObject.parentNode && this._rawObject.parentNode.selectedIndex;
\r
164 if( this._tag === 'INPUT' && X_Node_Attr_STATIC_VALUE_TYPES[ attrs[ 'type' ] ] ) break;
\r
167 case 'selectedIndex' :
\r
168 if( X_Node_Attr_HAS_VALUE[ this._tag ] ){
\r
169 if( this._newAttrs && X_Object_inObject( nameOrObj, this._newAttrs ) ) return this._newAttrs[ nameOrObj ];
\r
170 if( elm = X_UA_DOM.IE4 ? this._rawObject || X_Node__ie4getRawNode( this ) : this._rawObject ){
\r
171 if( !attrs ) attrs = this._attrs = {};
\r
172 return attrs[ nameOrObj ] = elm[ nameOrObj ]; // getAttribute( nameOrObj )?
\r
177 return attrs && attrs[ X_Node_Attr_renameForTag[ nameOrObj ] || nameOrObj ];
\r
180 function X_Node_Attr_setAttr( that, attrs, newAttrs, name, v ){
\r
182 // case 'type' : TODO IE は input, button, object に対して type の再設定が出来ない _state が要素生成済なら不可
\r
188 v = ( v !== 'ie4uid' + that._uid ) ? v : undefined;
\r
189 // TODO unique の check
\r
190 if( v !== that._id ){
\r
192 that._flags |= X_Node_State.DIRTY_ID;
\r
193 that._flags & X_Node_State.IN_TREE && X_Node_reserveUpdate();
\r
198 return that.className( v );
\r
201 return that.cssText( v );
\r
203 return that.text( v );
\r
205 return that.html( v );
\r
208 if( name.indexOf( 'on' ) === 0 ){
\r
209 X.Logger.warn( 'xnode.attr("' + name + '") is wrong, xnode.listen() & xnode.unlisten().' );
\r
213 name = X_Node_Attr_renameForTag[ name ] || name;
\r
214 if( attrs[ name ] === v ) return;
\r
217 newAttrs[ name ] = undefined;
\r
218 if( attrs.hasOwnProperty( name ) ) delete attrs[ name ];
\r
220 newAttrs[ name ] = attrs[ name ] = v;
\r