zoukankan      html  css  js  c++  java
  • [AngularJS] Best Practise

    Module definitions


     

    Angular modules can be declared in various ways, either stored in a variable or using the getter syntax. Use the getter syntax at all times (angular recommended).

    Bad:

    var app = angular.module('app', []);
    app.controller();
    app.factory();

    Good:

    angular
      .module('app', [])
      .controller()
      .factory();

    From these modules we can pass in function references.

    Module method functions


     

    Angular modules have a lot of methods, such as controllerfactorydirectiveservice and more. There are many syntaxes for these modules when it comes to dependency injection and formatting your code. Use a named function definition and pass it into the relevant module method, this aids in stack traces as functions aren't anonymous (this could be solved by naming the anonymous function but this method is far cleaner).

    Bad:

    var app = angular.module('app', []);
    app.controller('MyCtrl', function () {
      
    });

    Good:

    function MainCtrl () {
      
    }
    angular
      .module('app', [])
      .controller('MainCtrl', MainCtrl);

    Define a module once using angular.module('app', []) setter, then use the angular.module('app')getter elsewhere (such as other files).

    To avoid polluting the global namespace, wrap all your functions during compilation/concatenation inside an IIFE which will produce something like this:

    Best:

    (function () {
      angular.module('app', []);
      
      // MainCtrl.js
      function MainCtrl () {
      
      }
      
      angular
        .module('app')
        .controller('MainCtrl', MainCtrl);
        
      // AnotherCtrl.js
      function AnotherCtrl () {
      
      }
      
      angular
        .module('app')
        .controller('AnotherCtrl', AnotherCtrl);
        
      // and so on...
        
    })();
  • 相关阅读:
    short s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 += 1;有什么错?
    SpringMVC常用的注解有哪些?
    Spring支持的ORM?
    什么是代理?
    一对一、一对多的关联查询 ?
    iHTML 的 form 提交之前如何验证数值文本框的内容全部为数字?
    解释JDBC抽象和DAO模块?
    Bean 工厂和 Application contexts 有什么区别?
    GitHub的注册
    HTML的学习
  • 原文地址:https://www.cnblogs.com/Answer1215/p/4121419.html
Copyright © 2011-2022 走看看