Home > Web Front-end > JS Tutorial > body text

AngularJS modular applications

php中世界最好的语言
Release: 2018-05-02 11:20:16
Original
1036 people have browsed it

This time I bring you AngularJSModular application, what are the precautions of AngularJS modular application, the following is a practical case, let’s take a look one time.

1. Benefits of modularization

(1) Achieve clearer logic and strong readability;
(2)Team The development division of labor is clear and easy to control;
(3) Make full use of reusable code;
(4) Abstract public modules and have strong maintainability;
(5) Modular legacy systems are easy to assemble Develop new similar systems.

2. Definition of AngularJS module

(1) How to use module() of angular objects:

  // 定义一个无依赖模块
  angular.module('appModule',[]);
  // 定义一个依赖module1、module2的模块
  angular.module('appModule',['module1','module2']);
Copy after login

(2)angular.module() method: receives three parameters

The first is the name of the module, and the second is an array, indicating the name of the module on which the module depends. If you do not need to rely on other modules, just pass in an empty array. The third parameter is optional and receives a method for configuring the module. Its function is the same as the config() method of the module instance.

angular The .module() method returns a module instance object. You can call the object's controller(), directive(), filter() and other methods to add controller, instructions, filters# to the module. ## and other components.

(3) Page reference module: ng-app directive

<html ng-app="appMobile">
Copy after login

3. Use modules to resolve naming conflicts

Two pages share a js file. The definition of the controller is placed in common.js. When the controller names defined by the two pages are the same, a conflict will occur. AngularJS uses modularization to solve the naming problem. Conflict. Call the angular.module() method to create two module instances, and call the controller() method of the two module instances to create two controllers with the same name, but the two controllers belong to different modules. Although the html page The controller names in are all UserController, but they belong to different modules, thus avoiding conflicts.

var loginModule = angular.module("loginModule",[]);
loginModule.controller("UserController",function($scope,$log){
  
  $scope.uname = "login";
  $scope.pword = "admin";
  $scope.submit = function(){
    alert("登录模块: UserController");
  }
})
var registerModule = angular.module("registerModule",[]);
registerModule.controller("UserController",function($scope,$log){
  
  $scope.uname = "register";
  $scope.pword = "admin";
  $scope.submit = function(){
    alert("注册模块: UserController");
  }  
})
Copy after login

4. Best practices for modularization

Assume the project name: app, including two modules: login and register:

├─app
│ │
│ ├──css---------------CSS样式
│ ├──img---------------图片资源
│ ├──js----------------JS代码  
│ │  common.js // 公共JS代码
│ │
│ ├──modules
│ │  │
│ │  ├─login----------------登录模块
│ │  │  │  
│ │  │  │   loginModule.js----------------登录模块定义
│ │  │  │   
│ │  │  ├─css
│ │  │  ├─js  
│ │  │  │   directives.js
│ │  │  │   filters.js
│ │  │  │   controllers.js----------------控制器定义
│ │  │  │  
│ │  │  │  
│ │  │  └─views  
│ │  │     login.html
│ │  │     
│ │  └──register----------------注册模块  
│ │     │  
│ │     │   registerModule.js----------------注册模块定义
│ │     │   
│ │     ├─css
│ │     ├─js  
│ │     │   directives.js
│ │     │   filters.js
│ │     │   controllers.js----------------控制器定义
│ │     │  
│ │     │  
│ │     └─views  
│ │       register.html
│ │
Copy after login
I believe you have mastered the method after reading the case in this article. For more exciting information, please pay attention to other related articles on the PHP Chinese website!

Recommended reading:

Using the swiper plug-in in vue

Express default log component morgan usage detailed explanation

The above is the detailed content of AngularJS modular applications. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template