Опытные функции обратного вызова, глотая исключения

Использование Версии прототипа 1.6.0.2.

У меня есть типичная проблема, где исключения глотают, когда они брошены в функцию обратного вызова, обычно когда я пытаюсь обработать ответ на Ajax.Request звонить. Вот простой пример:

Разметка HTML:

<input type="button" id="myButton" value="Press Me" />

JavaScript:

MYSITE = {};

document.observe("dom:loaded", function () {

    // Set up our helper object
    MYSITE.pageHelper = new MYSITE.PageHelper();

});


MYSITE.PageHelper = function() {

    console.log("PageHelper called.");

    $("myButton").observe("click", this.makeCall.bindAsEventListener(this));

};

MYSITE.PageHelper.prototype.makeCall = function() {

    console.log("Make call.");

    new Ajax.Request(
            "remoteCall.cfm", 
            {
                method: 'get', 
                parameters: "", 
                onComplete: this.handleCallback.bindAsEventListener(this)

            });


};

MYSITE.PageHelper.prototype.handleCallback = function(resp) {

    console.log("Start callback processing...");

    var x = missingVar + "text"; // This line generates an exception...

    console.log("Finished callback processing.");
};

Хорошо, таким образом, проблема - то, что при выполнении этого кода в Firefox с Firebug, никакое исключение не будет произведено для незаконной строки - это глотают. Большой глоток. Единственным путем я знаю для ловли их (скажите, отлаживаю ли я), должен перенести содержание функции обратного вызова в попытке/выгоде. Например:

MYSITE.PageHelper.prototype.handleCallback = function(resp) {

    try {

        console.log("Start callback processing...");

        var x = missingVar + "text"; // This line generates an exception...

        console.log("Finished callback processing.");

    } catch (e) {
        console.log(e);
    }
};

Кто-либо еще когда-либо сталкивался с этой проблемой? Какие-либо обходные решения там?

Заранее спасибо!

5
задан Rob W 28 December 2011 в 13:33
поделиться

1 ответ

На сегодняшний день это известное поведение:

http://groups.google.com/group/prototype-scriptaculous/browse_thread/thread/ e71c7a6bfb656380 / 7d1c8a23edc07f03? lnk = gst & q = exception + swallowed #

Здесь есть билет на усовершенствование для работы с этими проглоченными исключениями:

https://prototype.lighthouseapp.com/projects/8886/tickets/ 634-no-exception-on-error-in-oncreate-method-of-ajaxrequest

Одно из предлагаемых решений - добавить следующий код (спасибо Гленну Мейнарду!):

Ajax.Responders.register({ 
        onException: function(request, exception) { 
                (function() { throw exception; }).defer(); 
        } 
});

Надеюсь, что это поможет другим в том же проблема до тех пор, пока не будет реализовано более постоянное решение.

4
ответ дан 15 December 2019 в 00:55
поделиться
Другие вопросы по тегам:

Похожие вопросы: