首頁 >web前端 >js教程 >javascript實作網頁子頁遍歷回呼的方法(涉及 window.frames、遞歸函數、函數上下文)_javascript技巧

javascript實作網頁子頁遍歷回呼的方法(涉及 window.frames、遞歸函數、函數上下文)_javascript技巧

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB原創
2016-05-16 15:48:411882瀏覽

本文實例講述了javascript實作網頁子頁遍歷回呼的方法(涉及 window.frames、遞歸函數、函數上下文)。分享給大家供大家參考。具體如下:

提煉於本人手寫的純 JavaScript 工具程序,用於遍歷當前網頁的所有子頁面 並執行迭代回調,且回調函數返回值可用於結果回傳,有助於減少閉包變量~

其特點在於 —— 遞歸遍歷時只檢索子頁面的 Window 對象,不立即執行回呼函數,而是在檢索結束後在普通循環結構中回調。這樣可以盡量減少 遞歸呼叫時的記憶體消耗,也簡化了程式結構,易於維護

全域函數 Frame_Each( CallBack ):

(function (BOM) {
  function All_Frames(iWindow) {
    var _Frames_ = [].slice.call(iWindow.frames, 0);
    for (var i = 0; i < _Frames_.length; i++)
      _Frames_ = _Frames_.concat( arguments.callee(_Frames_[i]) );
    return _Frames_;
  }
  BOM.Frame_Each = function (CallBack) {
    var Frames = [this].concat( All_Frames(this) );
    if (! CallBack) return Frames;
    for (var i = 0, CBR; i < Frames.length; i++) {
      try { Frames[i].name; } catch (iError) { continue; }
      CBR = CallBack.apply(Frames[i], [].slice.call(arguments, 1));
      if (CBR === false) break;
      else if (CBR === undefined) continue;
      return CBR;
    }
  };
})(self);

使用範例:

// 无参数 —— 返回一个数组,包含函数调用所在的 Window 对象及其子页面的 Window,其顺序同递归遍历
var Pages = Frame_Each();
console.log( Pages.length );
// 定义回调 —— 回调返回值功能与普通循环语句的对应:
//  1. undefined:continue
//  2. false:break
//  3. 其它任何值:break && return Value
var Search_Result = Frame_Each(function () {
  var iFocus = this.document.activeElement;
  switch ( iFocus.tagName.toLowerCase() ) {
    case 'body':   return false;
    case 'iframe':  return;
  }
  return iFocus;
});
Search_Result.innerHTML = 'Hello, Focus!';

希望本文所述對大家的javascript程式設計有所幫助。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn