我正在尝试将ECMA6集成到现有的Angular项目中。我正在寻找一个最佳实践来解决我们遇到的一些问题。所有组件(我们有很多)都有以下文件结构:
-app/
--components/
--somemodul/
--somemodul.mdl.js
--somemodul.drv.js
--somemodul.ctrl.js
--somemodul.srv.js
--somemodul.tmpl.html
-app.js
//somemodul.mdl.js
(function () {
angular.module('somemodul', []); //initiate module
})()
//somemodul.drv.js
(function () {
angular.module('somemodul')
.directive('someModuleDrv', someModuleDrv); //add to module
function someModuleDrv() {
// CODE
}
})()
//somemodul.ctrl.js
(function () {
angular.module('somemodul')
.controller('someModuleCtrl', someModuleCtrl); //add to module
function someModuleCtrl() {
// CODE
}
})()
//somemodul.srv.js
(function () {
angular.module('somemodul')
.service('someModuleSrv', someModuleSrv); //add to module
function someModuleSrv() {
// CODE
}
})();在构建时,Gulp执行concat,一切工作正常。
使用ECMA6,我们需要将所有这些模块导入到app.js中。现在我看到了两个选择:
1)将我所有的“某些模块”文件合并成一个文件:
//somemodul.js
export default angular.module('somemodul', [])
.directive('someModuleDrv', someModuleDrv)
.service('someModuleSrv', someModuleSrv)
.controller('someModuleCtrl', someModuleCtrl);
function someModuleDrv() { };
function someModuleSrv() { };
function someModuleCtrl() { };2)将所有子模块导入到‘somemodule.mdl.js’中:
//somemodul.mdl.js
import someModuleDrv from './somemodul.drv.js'
import someModuleSrv from './somemodul.srv.js'
import someModuleCtrl from './somemodul.ctrl.js'
export default angular.module('somemodul', [
someModuleDrv.name,
someModuleSrv.name,
someModuleCtrl.name
]);
//somemodul.drv.js
export default angular.module('somemodul.drv', [])
.directive('someModuleDrv', someModuleDrv);
function someModuleDrv() {
// CODE
}
//somemodul.srv.js
export default angular.module('somemodul.srv', [])
.directive('someModuleSrv', someModuleSrv);
function someModuleSrv() {
// CODE
}
//somemodul.ctrl.js
export default angular.module('somemodul.ctrl', [])
.directive('someModuleCtrl', someModuleCtrl);
function someModuleCtrl() {
// CODE
}这两个选项都有效。不幸的是,这两种选择都需要大量的动手工作。所以我正在寻找其他可能的解决方案……
谢谢。
发布于 2016-02-14 22:56:10
找到的解决方案是使用require.context()。
在我的例子中,它看起来是这样的:
//somemodul.js
export default angular.module('somemodul', [])
/**
* Requires all directives from subdirectories.
* @param requireContext
* @returns {*}
*/
function requireAll(requireContext) {
return requireContext.keys().map(requireContext);
}
requireAll(require.context(".", true, /^\.\/.*\.js$/));我尝试过不使用require和stay only with (export/import),但看起来这只是一种方法。
https://stackoverflow.com/questions/35343362
复制相似问题