* <h4>必須プロパティ</h4>\r
* <dl>\r
* <dt>url<dd>URL\r
- * <dt>type<dd>'xhr', 'jsonp', 'image', 'img'\r
+ * <dt>type<dd>'xhr', 'jsonp', 'form', 'image', 'img'\r
* <dt>xhr<dd>URL { url : 'hoge', type : 'xhr' } の省略形\r
* <dt>jsonp<dd>URL { url : 'hoge', type : 'jsonp' } の省略形\r
+ * <dt>form<dd>URL { url : 'hoge', type : 'form' } の省略形\r
* <dt>image, img<dd>URL { url : 'hoge', type : 'image' } の省略形\r
* </dl>\r
* <h4>XHR 用プロパティ</h4>\r
* <dt>params<dd>url パラメータを object で渡すことが出来る。\r
* <dt>callbackName<dd>callback(json) コールバック名が固定されている際に指定。または &callback=hoge 以外の名前でコールバックを指定する場合に params と callbackName に書いておく。url パラメータに callback が無く、callbackName もない場合、フレームワーク内で自動で設定される\r
* <dt>charset<dd>ページと異なるjsonpを読み込む場合に指定 'EUC-JP', 'Shift-JIS' 等 script タグの charset に入る。https://code.google.com/p/ajaxzip3/issues/detail?id=5\r
- * <dt>useFireWall<dd>異なるドメインに jsonp を読み込んだ後、xdomain iframe 通信を使ってデータを受け取る。不正なコードの実行を防ぐことが出来る、未実装\r
+ * <dt>useFireWall<dd>異なるドメインに jsonp を読み込んだ後、xdomain iframe 通信を使ってデータを受け取る。不正なコードの実行を防ぐことが出来る(はず)、未実装\r
* </dl>\r
* \r
* <h4>Form 用プロパティ</h4>\r
* <dl>\r
- * <dt>params<dd>url パラメータを object で渡すことが出来る。\r
* <dt>method<dd>'GET' or 'POST'\r
- * <dt>target<dd>'_self', '_parent', '_top' の場合、ページから離脱する。target を指定せず同一ドメインの場合 response に body.innerHTML が返る。\r
+ * <dt>params<dd>パラメータ object は input タグの name & value に展開される。object を入れ子にすることはできない。\r
+ * <dt>target<dd>'_self', '_parent', '_top' の場合、ページから離脱する。target を指定せず同一ドメインの場合 response に body.innerHTML が返る。TODO X.Window\r
+ * <dt>timeout<dd>ms タイムアウト時間、省略可能\r
+ * <dt>charset<dd>未実装\r
* </dl>\r
* \r
* @alias X.Net\r
opt[ 'auth' ] = auth; // auth は deep copy されるとまずい\r
};\r
\r
- // params を url に追加\r
- if( opt[ 'params' ] ){\r
+ // params を url に追加 但し form は除く\r
+ if( opt[ 'params' ] && type !== X_NET_TYPE_FORM ){\r
url = X_URL_create( url, opt[ 'params' ] );\r
delete opt[ 'params' ];\r
}; \r
\r
// XDomain 不可 -> Flash, Gears, Silverlight, canUseGadget なら gadget に切替?\r
// PUT DELETE UPDATE 不可 -> Flash, Gears, Silverlight, canUseGadget なら gadget に切替?\r
- // xプロトコル な binary のロード -> gadget 内で proxyURL による XHR\r
+ // xプロトコル(X_URL_isSameProtocol) な binary のロード -> gadget 内で proxyURL による XHR\r
// or X_EVENT_ERROR\r
\r
opt[ 'dataType' ] = opt[ 'dataType' ] || X_URL_getEXT( url );\r
};\r
\r
opt.netType = type;\r
- opt[ 'url' ] = url; \r
+ opt[ 'url' ] = url;\r
\r
X_Pair_create( this, opt );\r
\r
\r
X_XHR,\r
X_JSONP,\r
- X_NET_FormWrapper,\r
- X_NET_ImageWrapper,\r
+ X_FormSender,\r
+ X_ImgLoader,\r
X_GadgetXHR,\r
\r
X_NET_currentWrapper,\r
this[ 'unlisten' ]( X_EVENT_COMPLETE, X_NET_proxyDispatch )\r
[ 'dispatch' ]( X_EVENT_COMPLETE );\r
};\r
- X_NET_shiftQueue();\r
+ X_NET_shiftQueue( true );\r
X_Pair_release( this );\r
X_NET_completePhase = 0;\r
} else\r
if( this === X_NET_currentQueue ){\r
X_NET_currentWrapper.cancel();\r
- X_NET_shiftQueue();\r
+ X_NET_shiftQueue( true );\r
flag = true;\r
} else\r
if( ( i = X_NET_QUEUE_LIST.indexOf( this ) ) !== -1 ){\r
this[ 'listenOnce' ]( X_EVENT_COMPLETE, X_NET_proxyDispatch )\r
[ 'asyncDispatch' ]( 32, { type : X_EVENT_COMPLETE, 'lastEventType' : e.type } );\r
\r
+ // target を上書き X_NET_currentWrapper -> X_NET_currentQueue\r
+ e[ 'target' ] = e[ 'currentTarget' ] = this;\r
this[ 'asyncDispatch' ]( e );\r
break;\r
\r
};\r
};\r
\r
-function X_NET_shiftQueue(){\r
- var auth, authSettings;\r
+// TODO _busy は X.Net で触る.\r
+function X_NET_shiftQueue( currentKilled ){\r
+ var q, auth, authSettings;\r
\r
if( X_NET_currentQueue ){\r
- if( X_NET_currentWrapper._busy ) return;\r
+ if( !currentKilled ) return;\r
\r
X_NET_currentWrapper\r
[ 'unlisten' ]( [ X_EVENT_PROGRESS, X_EVENT_SUCCESS, X_EVENT_ERROR ], X_NET_currentQueue, X_NET_proxyDispatch )\r
if( !X_NET_QUEUE_LIST.length ) return;\r
\r
\r
- X_NET_currentQueue = X_NET_QUEUE_LIST.shift();\r
+ X_NET_currentQueue = q = X_NET_QUEUE_LIST.shift();\r
X_NET_currentData = X_Pair_get( X_NET_currentQueue );\r
\r
switch( X_NET_currentData.netType ){\r
case 1 :\r
case 2 :\r
if( !( auth[ 'dispatch' ]( X_EVENT_NEED_AUTH ) & X_CALLBACK_PREVENT_DEFAULT ) ){\r
- authSettings.lazyRequests = authSettings.lazyRequests || [];\r
- authSettings.lazyRequests.indexOf( X_NET_currentQueue ) === -1 && authSettings.lazyRequests.push( X_NET_currentQueue );\r
+ // event 内で kill されていないことを確認\r
+ if( X_NET_currentQueue === q ){\r
+ authSettings.lazyRequests = authSettings.lazyRequests || [];\r
+ authSettings.lazyRequests.indexOf( q ) === -1 && authSettings.lazyRequests.push( q );\r
+ X_NET_currentQueue = null;\r
+ X_NET_shiftQueue(); \r
+ };\r
+ } else {\r
+ X_NET_currentQueue === q && q[ 'kill' ]();\r
};\r
- X_NET_currentQueue = null;\r
- X_NET_shiftQueue();\r
- break;\r
+ return;\r
case 3 : // refresh token\r
X_NET_QUEUE_LIST.push( X_NET_currentQueue );\r
X_NET_currentQueue = null;\r
X_NET_currentWrapper = X_JSONP || X_TEMP.X_JSONP_init();\r
break;\r
case X_NET_TYPE_FORM :\r
- X_NET_currentWrapper = X_NET_FormWrapper || X_TEMP.X_NET_Form_init();\r
+ X_NET_currentWrapper = X_FormSender || X_TEMP.X_FormSender_init();\r
break;\r
case X_NET_TYPE_IMAGE :\r
- X_NET_currentWrapper = X_NET_ImageWrapper || X_TEMP.X_NET_Image_init();\r
+ X_NET_currentWrapper = X_ImgLoader || X_TEMP.X_ImgLoader_init();\r
break;\r
};\r
\r