Structuring my AngularJS application

后端 未结 5 1739
旧巷少年郎
旧巷少年郎 2021-01-30 10:57

I\'m totally newbie at using AngularJs and although I\'ve been through the tutorials, I still have loads of unanswered questions in my mind. My main concern right now is how sho

相关标签:
5条回答
  • 2021-01-30 11:27

    The draw back I have found to the approach the yeoman generator takes is that it doesn't really lineup with the angular modules so it doesn't feel very cohesive to me. So as the project gets larger and you are working on a particular component I found myself flipping around a lot in the source tree.

    I have recently come across a different approach here. This approach groups the files by angular modules and feels more cohesive to me. One possible drawback to this is the fact you are required to build the site you can't just run it in place. The grunt watch task in that project helps with this though.

    0 讨论(0)
  • 2021-01-30 11:32

    For those who are interested, I made a "modularized" version of Angular Seed that fits better with Misko's best practices: https://github.com/sanfordredlich/angular-brunch-seed-modularized

    It's set up with Brunch so you very quickly get page reloading, test running and much more. You can be developing quickly and if you follow the patterns in the code, your application should scale reasonably well. Enjoy!

    0 讨论(0)
  • 2021-01-30 11:40

    [EDIT] I wrote an article on my blog to explain things in more details:

    read it on sam-dev.net and you can now read part II, with code sample.

    I'll answer my own question. Not because I think it's the best approach, but just because it's the one I've decided to go with.

    This is how I've divided my business modules into folders

    • app
      • businessModule
        • controllers
          • index.js
          • firstCtrl.js
          • secondCtrl.js
        • directives
        • services
        • views
        • filters
      • anotherBusinessModule
      • shared
      • app.js
      • index.html

    Each module has its own folder structure for controllers, directives, etc...

    Each folder has an index.js file and then other files to separates each controller, each directive, etc...

    The index.js file contains the definition of the module. For instance for the controllers of the businessModule above:

    angular.module('myCompany.businessModule.controllers', []);
    

    There's no dependencies here, but there could be any.

    Then in firstCtrl.js, I can reuse that module and add the controller to it:

    angular.module('myCompany.businessModule.controllers').controller('firstCtrl',     
    
            function(){
    });
    

    Then the app.js aggregates all the module that I want for my application by adding them to the dependencies array.

     angular.module('myApp', ['myCompany.businessModule', 'myCompany.anotherBusinessModule']);
    

    The shared folder contains directives and other things that are not specific to a business module and that can be reused anywhere.

    Again, I don't know if it's the best approach, but it definitely works for me. Maybe it can inspire other people.

    EDIT

    As the index.js files contain modules declarations, they must be referenced in the html page before any other application scripts. To do so, I've used the IBundleOrderer of ASP.NET MVC 4:

     var bundle = new ScriptBundle("~/bundles/app") { Orderer = new AsIsBundleOrderer() };
     bundles.Add(bundle.IncludeDirectory("~/app", "*.js", true));
    
    public class AsIsBundleOrderer : IBundleOrderer
    {
        public IEnumerable<FileInfo> OrderFiles(BundleContext context, IEnumerable<FileInfo> files)
        {
            files = files.OrderBy(x => x.Name == "index.js" ? 0 : 1);
            return files;
        }
    }
    
    0 讨论(0)
  • 2021-01-30 11:47

    you should go to the yeoman https://github.com/yeoman/yeoman and yeoman generator structure: https://github.com/yeoman/generator-angular, it becomes a better solution to setup application than angular-seed. For different business modules, you should create different app and share services and directives

    0 讨论(0)
  • 2021-01-30 11:49

    Sam's method seems to be the way to go in most cases. The current Angular documentation has it setup as a module for each controller, service, etc, but this has been contradicted by Miško himself from google.

    In a recent Angularjs Best Practices video by Miško, he shows how the structure of modules could be laid out for ease of testing as well as easy scaling. Keep in mind how you structure the modules is not supposed to affect performance within an angular app.

    From developing angular apps, I would suggest using the best practices method for the aforementioned reasons. You may wish to make your own node script to generate your controllers, etc for the time being which could include say the module you wish to create the controller in and the name, which would then auto generate your controller and proper test spec creation.

    If you want a great read on the setup there is an excellent post here regarding setting up the project based on where you think it will be heading.

    0 讨论(0)
提交回复
热议问题