在Backbone和requirejs 2x应用程序中,仅当应用程序合并时才通过grunt-contrib-require,window.onerror会停止捕获错误。
在Backbone应用程序之前和之外声明的window.onerror函数id,并将错误发送到后端。
很抱歉,无法发布大部分应用程序,但感兴趣的部分
这是我的app / main.js文件
require(["config"], function () {
// config is a require.config({}); definition
require(["app", "router"], function (app, Router) {
app.initialize(new Router());
});
});
关于requirejs任务的Gruntfile.js部分
requirejs : {
debug : {
options : {
mainConfigFile : "app/config.js",
generateSourceMaps : false,
include : [ "main" ],
insertRequire : [ "main" ],
out : "app.combined.js",
optimize : "none",
findNestedDependencies : true,
name : "config",
baseUrl : "app",
wrap : false,
preserveLicenseComments : false
}
}
}
嵌入未合并的申请表:
<script>
window.onerror = function(msg, url, line, colno, error) {
console.debug('onerror',arguments);
// data will be sent to backend
// TRACE FIRED
}
</script>
<script src="require.js" data-main="app/main"></script>
组合申请的嵌入:
<script>
window.onerror = function(msg, url, line, colno, error) {
console.debug('onerror',arguments);
// data will be sent to backend
// TRACE NOT FIRED
}
</script>
<script src="app.combined.js" ></script>
欢迎任何建议!谢谢。
答案 0 :(得分:0)
我找到了解决方法。
我应该在窗口加载后声明window.onerror 。
$(window).load(function() {
window.onerror = function(msg, url, line, colno, error) {
console.debug('onerror',arguments);
// data will be sent to backend
// TRACE FIRED
};
});
<script src="app.combined.js" ></script>