我对 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>