我遇到RequireJS和Modernizr的问题。
我想要Modernizr资源。以及身体的其他一切。原因是Modernizr需要在DOMContentLoad之前做一些事情。我希望能够使用RequireJS将Modernizr模块加载到其他模块中。如何在开发和生产环境中实现这一目标?我使用requirejs来拉取所有依赖项并缩小所有资源。并且yeoman构建用缩小版本替换<script data-main="scripts/main" src="scripts/vendor/require.js"></script>
。
:
<!-- build:js ikl.app.js -->
<script data-main="scripts/main" src="scripts/vendor/require.js"></script>
<!-- endbuild -->
<script>
requirejs.config({
paths: {
'jquery' : 'vendor/jquery',
'handlebars' : 'vendor/handlebars',
'ember' : 'vendor/ember',
'ember-data' : 'vendor/ember-data',
'modernizr' : 'vendor/modernizr' // This should be removed
},
baseUrl: 'scripts',
shim: {
'jquery' : {
exports : 'jQuery'
},
'ember': {
deps: ['jquery', 'handlebars'],
exports: 'Ember'
},
'ember-data': {
deps: ['ember'],
exports: 'DS'
},
'handlebars': {
exports: 'Handlebars'
},
'modernizr': {
exports: 'Modernizr'
}
}
});
require([
'modules/system/controllers/system.controller',
'jquery',
'ember',
'ember-data',
'handlebars',
'modernizr'
],
function( systemController ) {
systemController.renderView();
}
);
</script>
答案 0 :(得分:34)
你应该能够同时获得两者。
最后,在引导需要之前,定义modernizr模块
define('modernizr', [], Modernizr);
require(['foo', 'bar', 'modernizr'], function(foo, bar, modernizr) {
//..profit
}