2 * http://msdn.microsoft.com/ja-jp/library/ie/hh180174%28v=vs.85%29.aspx
\r
3 * 孤立するとウィンドウ オブジェクトのプロパティが消去される
\r
5 * http://qiita.com/sou/items/3380d4fa9b08b27bb387
\r
6 * モバイルブラウザでの iframe の挙動(Mobile Safari, Chrome for Android)
\r
8 * @alias X.Util.NinjaIframe
\r
9 * @class NinjaIframe 隠し iframe 機能を提供します。
\r
12 var X_NinjaIframe = X[ 'Util' ][ 'NinjaIframe' ] = Node[ 'inherits' ](
\r
15 /** @lends NinjaIframe.prototype */
\r
17 /* autoRefresh : 0, */
\r
20 * iframe の contentWindow
\r
26 * iframe に write する html 文字時列
\r
37 * iframe への html 文字列の write が完了した
\r
42 'Constructor' : function( html ){
\r
45 this._name = 'hidden-iframe-' + X_Timer_now();
\r
46 // https://github.com/polygonplanet/Pot.js/blob/master/src/Worker.js
\r
51 className : 'hidden-iframe',
\r
53 allowtransparency : 'no',
\r
61 // http://nanto.asablo.jp/blog/2011/12/08/6237308
\r
62 // IE 6/7 で文書間通信を実現するための一案
\r
63 if( X_UA[ 'IE' ] < 9 ){
\r
64 this[ 'attr' ]( 'src', 'about:blank' );
\r
66 // Safari 2.0.* bug: iframe's absolute position and src set.
\r
67 if( !X_UA[ 'Webkit' ] ){
\r
68 this[ 'css' ]( { position : 'absolute' } );
\r
71 if( html ) this._contentHTML = html;
\r
73 this[ 'appendTo' ]( X_Node_systemNode )
\r
74 [ 'listenOnce' ]( X_EVENT_KILL_INSTANCE, X_Util_NinjaIframe_handleEvent );
\r
76 X_ViewPort[ 'listenOnce' ]( X_EVENT_AFTER_UPDATE, this, X_Util_NinjaIframe_handleEvent );
\r
80 * iframe 内をリフレッシュ、または内容を上書きする
\r
81 * @param {string=} opt_contentHTML html文字列
\r
82 * @return {NinjaIframe} チェーンメソッド
\r
84 'refresh' : function( opt_contentHTML ){
\r
85 var raw = this[ '_rawObject' ],
\r
88 this._ready = false;
\r
91 this._contentHTML = opt_contentHTML;
\r
95 if( X_UA[ 'IE5x' ] ){
\r
96 this._iwin.location.href = 'about:blank'; // reload() では、IE5.5(IETester)で2回目移行の操作でerrorが出る(doc取得やopen,writeで)
\r
98 this._iwin.location.reload();
\r
101 if( !X_Type_isString( opt_contentHTML ) ) return this;
\r
103 this._contentHTML = opt_contentHTML;
\r
105 if( !( X_UA[ 'IE' ] < 9 ) ){
\r
106 X_Util_NinjaIframe_writeToIframe( this );
\r
116 function X_Util_NinjaIframe_handleEvent( e ){
\r
117 var raw = this[ '_rawObject' ];
\r
120 case X_EVENT_AFTER_UPDATE :
\r
121 this._iwin = raw.contentWindow || ( raw.contentDocument && raw.contentDocument.parentWindow ) || window.frames[ this._name ];
\r
122 // http://d.hatena.ne.jp/NeoCat/20080921/1221940658
\r
123 // こちらに名前をsetしないとtargetが動作しない
\r
124 if( X_UA[ 'IE' ] ) this._iwin.name = this._name;
\r
126 this[ 'listen' ]( X_UA[ 'IE' ] < 9 ? 'readystatechange' : [ 'load', 'error' ], X_Util_NinjaIframe_handleEvent );
\r
128 if( !( X_UA[ 'IE' ] < 9 ) ){
\r
129 X_Util_NinjaIframe_writeToIframe( this );
\r
132 //break; これあると IE8 で駄目!
\r
134 case 'readystatechange' :
\r
135 if( ( raw.readyState !== 'complete' && raw.readyState !== 'loaded' ) ) break;
\r
137 if( !this._ready ){
\r
138 X_Util_NinjaIframe_writeToIframe( this );
\r
143 console.log( 'iframe load.' );
\r
144 this[ 'asyncDispatch' ]( 'ninjaload' );
\r
148 this[ 'asyncDispatch' ]( 'ninjaerror' );
\r
151 case X_EVENT_KILL_INSTANCE :
\r
152 X_ViewPort[ 'unlisten' ]( X_EVENT_AFTER_UPDATE, this, X_Util_NinjaIframe_handleEvent );
\r
153 this._iwin && this._iwin.close();
\r
157 return X_CALLBACK_STOP_PROPAGATION;
\r
160 function X_Util_NinjaIframe_writeToIframe( that ){
\r
161 var raw = that[ '_rawObject' ],
\r
162 idoc = raw.contentDocument || that._iwin.document,
\r
163 html = that._contentHTML;
\r
165 that._ready = true; // これを削除すると ie6,7,8 で Stack overflow at line : 0 意味不明 'readystatechange' が繰り返し起こりループする??
\r
166 delete that._contentHTML;
\r
169 idoc.writeln( html );
\r