首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将ECMAScript-6集成到现有的AngularJS项目中

将ECMAScript-6集成到现有的AngularJS项目中
EN

Stack Overflow用户
提问于 2016-02-11 23:27:03
回答 1查看 727关注 0票数 0

我正在尝试将ECMA6集成到现有的Angular项目中。我正在寻找一个最佳实践来解决我们遇到的一些问题。所有组件(我们有很多)都有以下文件结构:

代码语言:javascript
复制
-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)将我所有的“某些模块”文件合并成一个文件:

代码语言:javascript
复制
//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’中:

代码语言:javascript
复制
//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
}

这两个选项都有效。不幸的是,这两种选择都需要大量的动手工作。所以我正在寻找其他可能的解决方案……

谢谢。

EN

回答 1

Stack Overflow用户

发布于 2016-02-14 22:56:10

找到的解决方案是使用require.context()。

在我的例子中,它看起来是这样的:

代码语言:javascript
复制
//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),但看起来这只是一种方法。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35343362

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档