1

我正在使用 RESTHub 2.0 主干堆栈

以下是我的 route.js

define(function (require) {

    'use strict';

    var $ = require('jquery');
    var Backbone = require('backbone');

    var HomeView = require('../views/home');

    var _pageView;

    var AppRouter = Backbone.Router.extend({

        initialize: function() {
            console.log("Router initialize");
            Backbone.history.start({ pushState: false, root: "/" });
            _pageView = new HomeView();
        },

        routes: {
            '': 'main',
            'test': 'test'
        },

        main: function() {
            console.log("Main route activated");
            require(['views/home'], function(HomeView) {
                _pageView.render(HomeView);
            });
        },

        test: function() {
            console.log("Test route activated");
            alert("test");
        }
    });

    return AppRouter;

});

浏览器控制台给了我以下错误

Error: Module name "../views/home" has not been loaded yet for context: _
http://requirejs.org/docs/errors.html#notloaded

为什么会触发此错误?

我知道,这会失败,因为 requirejs 需要确保在调用上面的工厂函数之前加载并执行所有依赖项。如果给define()一个依赖数组,那么requirejs假定所有依赖都列在那个数组中,它不会扫描工厂函数来寻找其他依赖。所以,要么不传入依赖数组。

但还是不行!

4

1 回答 1

3

错误给出的链接中,它说:

//THIS WILL FAIL
define(['require'], function (require) {
    var namedModule = require('name');
});

我认为您需要依赖数组中的模块:

define(['require', '../views/home'], function (require) {
    var namedModule = require('../views/home');
});

或者,您可以将所有模块添加到该依赖项列表中,并改用回调函数的参数:

define(['jquery', 'underscore', 'backbone', '../views/home'], function ($, _, Backbone, HomeView) {
    // now you dont need to use require(name) at all.
});
于 2013-04-16T16:00:29.367 回答