作为我正在构建的 Web 应用程序的一部分,可以同时从服务器输入多个命令。
处理这些命令时,数据将趋于更新,然后可能会发生相当大量的页面 HTML 生成。
在多个类似命令进来的那一刻,程序会对数据进行处理,然后每次都重新生成部分页面。这会导致大量浪费的处理时间。
因此,我正在尝试创建一个调用堆栈,因此在处理命令时,它会查看命令触发的函数是否在堆栈中,如果未找到,则添加它。
我的问题是将调用堆栈中的被调用函数保持在正确的范围内,同时还能够消除重复项。
基本代码:
var tools = {
functions:{
function1: function(){
return this;
},
function2: function(){
}
},
unique: function(arr){
var returnArr=[],
x, i;
for (x=0; x<arr.length; x++){
for (i=(x+1); i<arr.length; i++){
if (arr[x]===arr[i]){
arr.splice(i, 1);
}
}
returnArr.push(arr[x]);
}
return returnArr;
}
}
示例 1:
var callstack=[tools.functions.function1, tools.functions.function1];
callstack = tools.unique(callstack);
for (var x=0; x<callstack.length; x++){
console.log(callstack[x](), "should equal tools.functions");
}
这失败了,因为“this”将返回 [function()]
示例 2:
var callstack=[
(function(){return tools.functions.function1()}),
(function(){return tools.functions.function1()})
];
callstack = tools.unique(callstack);
for (var x=0; x<callstack.length; x++){
console.log(callstack[x](), "should equal tools.functions");
}
这会失败,因为您无法确保函数是唯一的,因此它仍会运行该函数两次。
这可以通过使用两个数组(一个跟踪函数名称,一个保存封装函数)并使它们保持同步来解决,但我不禁觉得必须有一种更清洁的方式使用 .打电话,但我看不到。
JSFiddle:http: //jsfiddle.net/Kj6E8/