分类分类
更新时间:2026-05-10 23:47:16作者:fang
本文实例讲述了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程序设计有所帮助。
相关
修真情缘角色扮演303.33 MBv1.0.02026-05-10
下载我的小独角兽女孩休闲益智380.89 MBv1.0.232026-05-10
下载超级种田男孩手机版经营养成1.31Gv1.0.92026-05-10
下载不必要的实验冒险游戏64.9 MBv1.1.592026-05-10
下载军师联盟策略游戏163.2 MBv0.0.12026-05-10
下载翻天喜地凑大钱手机版休闲益智138.72 MBv1.0.92026-05-10
下载东离剑游纪手游动作射击1.6Gv1.4.22026-05-10
下载天猫养车商家版App学习办公74.95 MBv0.6.12026-05-10
下载掌上命运方舟App手游辅助137.48 MBv1.9.12026-05-10
下载退役军人服务APP生活服务67.16 MBv1.2.52026-05-10
下载屯漫漫画APP资讯阅读23.06 MBv2.0.32026-05-10
下载蛋仔派对蛋壳App手游辅助185.73 MBv0.0.22026-05-10
下载









