JQuery выполнен не выполняется второй раз, когда ошибка происходит в первом выполненииJavascript

Форум по Javascript
Ответить
Anonymous
 JQuery выполнен не выполняется второй раз, когда ошибка происходит в первом выполнении

Сообщение Anonymous »

У меня проблемы со старым кодом, который я должен поддерживать, и задаться вопросом, как решить это лучше всего. Допустим, у меня есть несколько модулей, загруженных на странице, где у меня нет управления. Все эти модули имеют функцию init, в которой они ждут некоторых отложенных объектов /обещаний jQuery. ">
var d1 = jQuery.Deferred();
var d2 = jQuery.Deferred();
var d3 = jQuery.Deferred();

var p1 = d1.promise();
var p2 = d2.promise();
var p3 = d3.promise();

d1.resolve();
d2.resolve();

//I can not control this
function init1() {
jQuery.when(p3).done(function (v3) {
console.log("in init1 done");
//somewhere in the code is happening an error..
throw new Error("error happening here");
});
}

//this is my "init"
function init2() {
jQuery.when(p3).done(function (v3) {
console.log("in init2 done"); //this is never executed
});
}

try {
//when p1 is loaded, init1 is called.
//this is a module where I do not have control
jQuery.when(p1).done(function () {
init1();
});
}
catch {}

try {
//when the p2 file is loaded the init2 function is called
//this is my module
jQuery.when(p2).done(function () {
init2();
});
}
catch {}

//this is resolved at some later point
d3.resolve();< /code>
< /code>
< /div>
< /div>
< /p>
Так что теперь мой модуль ждет обещания P3, чтобы разрешить. Как и некоторые другие модули. Эти модули могут быть добавлены до моего. Когда в одном из этих модулей возникает ошибка, часть функции «выполнено» init2 никогда не выполняется. < /P>
Есть ли способ выполнить мой «модуль» каким -либо образом? Даже с ошибками, происходящими в функции выполненной init1? Единственный способ, которым я пришел, - это обернуть содержание «init1 dode» в блок Try Catch. Но я не контролирую эту часть.


Подробнее здесь: https://stackoverflow.com/questions/794 ... he-first-d
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Javascript»