Requirejs结合应用程序window.onerror错误处理

时间:2014-11-21 11:59:48

标签: javascript backbone.js error-handling requirejs grunt-contrib-requirejs

在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>

欢迎任何建议!谢谢。

1 个答案:

答案 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>