我有以下函数我想重构,并且正在寻找可以用来使其更加简化的任何提示/技巧。
function resolveNotifyPromises(type, elem) {
if (elem && elem.id) {
if (promises[type] && promises[type][elem.id] && promises[type][elem.id].defereds) {
for (var i = 0; i < promises[type][elem.id].defereds.length; i++) {
promises[type][elem.id].defereds[i].resolve(elem);
promises[type][elem.id].defereds.pop(promises[type][elem.id].defereds[i]);
}
}
} else if (type) {
if (promises[type] && promises[type].defereds) {
for (var i = 0; i < promises[type].defereds.length; i++) {
promises[type].defereds[i].resolve(type);
promises[type].defereds.pop(promises[type].defereds[i]);
}
}
} else {
if (promises.defereds) {
for (var i = 0; i < promises.defereds.length; i++) {
promises.defereds[i].resolve("all");
promises.defereds.pop(promises.defereds[i]);
}
}
}
}
function checkRefCountsAndNotify(type, elem) {
var propCount = 0;
if (type && elem) {
resolveNotifyPromises(type, elem);
refCounts[type][elem.id] = 0;
}
if (type) {
for (var prop in refCounts[type]) {
if (refCounts[type][prop] === 1) propCount++;
}
if (propCount === 0) resolveNotifyPromises(type);
}
if (propCount === 0) {
for (var prop in refCounts) {
for (var prop2 in refCounts[prop]) {
if (refCounts[prop][prop2] === 1) propCount++;
}
}
if (propCount === 0) resolveNotifyPromises();
}
}
notifyOnComplete: function (type, elem) {
promises.defereds = promises.defereds || [];
if (type) {
promises[type] = promises[type] || {};
promises[type].defereds = promises[type].defereds || [];
}
if (elem && elem.id) {
promises[type][elem.id] = promises[type][elem.id] || {};
promises[type][elem.id].defereds = promises[type][elem.id].defereds || [];
}
var defered = $q.defer();
if (elem && elem.id) {
promises[type][elem.id].defereds.push(defered);
} else if (type) {
promises[type].defereds.push(defered);
} else {
promises.defereds.push(defered);
}
checkRefCountsAndNotify();
return defered.promise;
}
答案 0 :(得分:1)
看起来你已经将一些带有不同参数的相关函数放入更大的函数中,这些函数一旦被调用,就会尝试找出你想要调用的函数。
我认为最好将它们变成具有更具体名称的不同功能。