相关疑难解决方法(0)

如何使用RequireJS实现延迟加载?

我们正在使用Backbone,RequireJS和Handlebars构建一个非繁琐的Web应用程序,好吧,我只是很好奇.目前,我们的每个型号排序如下:

define(['Backbone', 'js/thing/a', 'js/thing/b', 'js/lib/bob'], function(a, b, bob) {
  return Backbone.Router.extend({
    // stuff here
  });
});
Run Code Online (Sandbox Code Playgroud)

其中thing/a,thing/b都有自己的依赖关系,例如Handlebars模板等.现在发生的是在我的main.js中,所有"顶级"路由器都被加载并初始化; 每个顶级路由器都有一组依赖项(模型,视图等),每个依赖项都有自己的依赖项(模板,帮助程序,工具等).基本上,一个大树结构.

这种情况下的问题是整个树在页面加载时被解析并加载.我不介意每个人,因为我们最终将通过优化器运行它并最终得到一个大的单个文件(将RequireJS简化为基本上模块化框架).但是,我很好奇你是否可以按需加载视图和模板等内容.

还有就是"简化CommonJS的包裹解释说:" 在这里,所以我试过了:

define(function(require) {
  Backbone = require('Backbone');
  return Backbone.Router.extend({
    doStuff: function() {
      var MyView = require('js/myView');
      new MyView().render();
    }
  });
});
Run Code Online (Sandbox Code Playgroud)

但是,看看Chrome的网络检查器,似乎RequireJS - 即使没有触发触发doStuff处理程序的路径 - 仍会加载myView依赖项.问题:

  • 这有可能吗?RequireJS中是否有黑色魔法,它们在require()没有实际触发doStuff路线的情况下寻找呼叫?
  • 这是理论上正确的"按需"方式,需要延迟加载RequireJS模块和资源吗?
  • 如果使用这种表示法,r.js优化器是否仍然像宣传的那样工作?

javascript requirejs backbone.js js-amd

61
推荐指数
1
解决办法
2万
查看次数

标签 统计

backbone.js ×1

javascript ×1

js-amd ×1

requirejs ×1