2011-09-11 9 views
1

フォームを送信し、フォームの送信結果をiframeにリダイレクトする簡単なスクリプトを作成しています。単純なjs-すべてのフォームをページに送信するiframeのページの読み込みが完了したかどうかを確認する

私はIFRAMEを完全にフォームの送信結果をロードし終え、だけにしてそのIFRAMEのコンテンツを取得し、フォームのポストに私にそれを投稿した場合jsのコードはチェックしたいです。

私は、フォームのポストを送信するためにインラインフレームの内容だけでなく、コードを取得するためのコードを持って、私はただのiframeにロードされた新しいページは、ロードが完了したりしていないかどうかを判断する方法が必要です。私は読み込みが完了するのを待って、そのiframeのコンテンツを取り出して投稿します。

また、私は、Webブラウザのメインウィンドウで、Webページ内のすべてのフォームを提出するための簡単なJavaScript関数をしたいと思います。

答えて

1

ドキュメントがChromeとFFで準備ができているのに、IEがそれをサポートしていない場合、イベントリスナーを使用できます。代わりに、IEにはreadystateという名前のものがあります。以下は、イベントハンドラを追加するために必要なものすべてを処理する関数です。あなたはaddLoadHandlerを呼びたいと思うでしょう、残りはサポート関数です。

// Adds an onload handler for script and iframe elements (supports IE) 
var _addLoadHandlerCallbackFired = {}; 
function addLoadHandler(element, callback) { 
    if (typeof callback !== 'function') { return false; } 

    var callbackID = generateNumericID(); // Generate an ID for the callback 
    _addLoadHandlerCallbackFired[callbackID] = false; // Initialize its state as not fired 
    callback = queueCallback(callback, 'addLoadHandler:' + callbackID); // Support multiple callbacks on the same element 
    var wrappedCallback = function() { // Wrap callback to set state to fired when called 
      _addLoadHandlerCallbackFired[callbackID] = true; 
      return callback.call(element); 
    }; 

    // Attach standard load handler 
    addEventHandler(element, 'load', wrappedCallback); 

    /* Hack to replicate element.onload in IE 
    Adapted from Nick Spacek's code at https://gist.github.com/461797 */ 
    addEventHandler(element, 'readystatechange', function() { 
      if ((element.readyState === 'loaded' || element.readyState === 'complete') && _addLoadHandlerCallbackFired[callbackID] === false) { 
       return wrappedCallback.call(element); 
      } 
     }); 

    return true; 
} 

// Generates Locally Unique IDs (length parameter is optional) 
function generateNumericID(length) { 
    if (typeof length !== 'undefined' && typeof length !== 'number') { return false; } 

    if (typeof length === 'undefined') { 
     length = 20; // Maximum length before the browser uses scientific notation 
    } 
    return Math.floor(Math.random() * Math.pow(10, length)); 
} 

// Queues callback functions to be executed in FIFO order 
var _callbacksQueues = {}; 
function queueCallback(callback, id) { 
    if (typeof id === 'undefined') { id = callback; } 

    if (typeof _callbacksQueues[id] === 'undefined') { _callbacksQueues[id] = []; } 
    _callbacksQueues[id].push(callback); 

    return function() { 
     while (_callbacksQueues[id].length > 0) { 
      _callbacksQueues[id].shift().apply(this, arguments); 
     } 
    }; 
} 

// Attaches events with cross-browser support, properly setting the context of this 
function addEventHandler(element, event, handler, capture) { 
    if (!isDOMElement(element) || typeof event !== 'string' || typeof handler !== 'function') { return false; } 
    if (event.substr(0,2) === 'on') { event = event.substr(2); } // Strip the 'on' at the beginning of the event if it is present 

    if (typeof element.addEventListener === 'function') { // Primary way of adding event listeners 
     if (typeof capture === 'undefined') { capture = false; } 
     return element.addEventListener(event, handler, capture); 
    } else if (typeof element.attachEvent !== 'undefined') { // Special case for IE (also, strangely typeof element.attachEvent = 'object' in IE) 
     return element.attachEvent('on' + event, function(e) { return handler.call(element, e); }); 
    } else { 
     return false; 
    } 
} 

// Adapted from isPlainObject in jQuery 1.5.2 
function isDOMElement(object) { 
    return object && (typeEx(object) === 'object') && (object.nodeType || isWindow(object)); 
}; 

/* Like typeof, but can tell different types of built-in objects apart 
Adapted from jQuery 1.5.2 */ 
function typeEx(object) { 
    var parameterType = typeof object; 
    if (parameterType !== 'object') { 
     return parameterType; 
    } else { 
     if (object instanceof Date) { 
      return 'date'; 
     } else if (object instanceof Array) { 
      return 'array'; 
     } else if (object instanceof RegExp) { 
      return 'regexp'; 
     } else { 
      return 'object'; 
     } 
    } 
} 

/* A crude way of determining if an object is a window 
Taken from jQuery 1.5.2 */ 
function isWindow(object) { 
    return object && typeof object === "object" && "setInterval" in object; 
} 

ページ上のすべてのフォームを送信するためのものです。あなたはそれぞれを呼び出す必要があります。

var forms = document.getElementsByTagName('form'); 
for (var formIndex = 0; formIndex < forms.length; formIndex++) { 
    forms[formIndex].submit(); 
} 
:以下のコードは、それを行います
関連する問題