【发布时间】:2011-02-05 18:46:44
【问题描述】:
使用原型版本 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 运行此代码,则违规行不会输出异常 - 它被吞没了。吞咽。 我知道捕获这些的唯一方法(例如,如果我正在调试)是将回调函数的内容包装在 try/catch 中。例如:
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);
}
};
有没有其他人遇到过这个问题?有什么解决方法吗?
提前致谢!
【问题讨论】:
标签: javascript ajax prototypejs dhtml