专栏首页菜鸟计划angularjs MVC、模块化、依赖注入详解

angularjs MVC、模块化、依赖注入详解

一、MVC

<!doctype html>
<html ng-app>
    <head>
        <meta charset="utf-8">
    </head>
    <body>
        <div ng-controller="HelloAngular">
            <p>{{greeting.text}},Angular</p>
        </div>
    </body>
    <script src="js/angular-1.3.0.js"></script>
    <script src="HelloAngular_MVC.js"></script>
</html>
function HelloAngular($scope) {
    $scope.greeting = {
        text: 'Hello'
    };
}

model (模型层)--view(视图层)--controller(控制层)

第一步我们把需要展示的数据首先在model (模型层)上绑好;

第二步我们通过controller(控制层)在模型层和视图层之间建立起一座桥梁;

第三步我们把数据结果渲染到view(视图层);

MVC只是手段,终极目标是代码的模块化和复用!

二、模块化

在实际项目中我们会从ng-app开始,然后定义出一个总的模块名,在用这个总的模块名去定义不同的模块;需要依赖的模块会写在[ ]里面。

<!doctype html>
<html ng-app="HelloAngular">
    <head>
        <meta charset="utf-8">
    </head>
    <body>
        <div ng-controller="helloCtrl">
            <p>{{greeting.text}},Angular</p>
        </div>
    </body>
    <script src="js/angular-1.3.0.js"></script>
    <script src="HelloAngular_Module.js"></script>
</html>
var helloModule = angular.module("HelloAngular",[]);
helloModule.controller('helloCtrl',['$scope', function($scope){
    $scope.greeting = {
        text: 'Hello'
    };
}]);

这个是官方推荐的一个模块划分方式,结合前面的事例,就可以根据不同的业务,来划分出不同的模块,以达到前面所讲的代码的模块化和复用。方便协同开发和维护。

三、依赖注入

我们在划分模块的时候,依赖注入是必不可少的,因为通过依赖注入的方式,我们可以让一个独立的模块,拆分的更细小,更加低耦合,高内聚,复用性更好。

依赖注入是一种设计模式,在需要的地方通过参数进行传递。

依赖注入会事先自动查找依赖关系,因为$injector会负责为我们查找并加载它。

依赖注入有三种声明:1.推断式注入声明;2.显示注入声明;3.行内注入声明。

一般我们使用的都是行内注入声明,要注意的就是参数的顺序要一致。

最后提一个ngMin:一款为angularJS应用设计的预压缩工具,能够减少我们定义依赖关系所需的工作量,它会遍历整个angularJS应用并帮助我们设置好依赖注入。

<!doctype html>
<html ng-app="bookStoreApp">

<head>
    <meta charset="UTF-8">
    <title>BookStore</title>
    <script src="framework/1.3.0.14/angular.js"></script>
    <script src="framework/1.3.0.14/angular-route.js"></script>
    <script src="framework/1.3.0.14/angular-animate.js"></script>
    <script src="js/app.js"></script>
    <script src="js/controllers.js"></script>
    <script src="js/filters.js"></script>
    <script src="js/services.js"></script>
    <script src="js/directives.js"></script>
</head>

<body>
    <div ng-view></div>
</body>

</html>
var bookStoreApp = angular.module('bookStoreApp', [
    'ngRoute', 'ngAnimate', 'bookStoreCtrls', 'bookStoreFilters',
    'bookStoreServices', 'bookStoreDirectives'
]);
var bookStoreCtrls = angular.module('bookStoreCtrls', []);

bookStoreCtrls.controller('HelloCtrl', ['$scope',
    function($scope) {
        $scope.greeting = {
            text: 'Hello'
        };
    }
]);
var bookStoreServices = angular.module('bookStoreServices', []);

bookStoreServices.service('bookStoreService_1', ['$scope',
    function($scope) {}
]);

bookStoreServices.service('bookStoreService_2', ['$scope',
    function($scope) {}
]);

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • webpack学习(二):先写几个webpack基础demo

    一、先写一个简单demo1 1-1安装好webpack后创建这样一个目录: ? 1-2:向src各文件和dist/index.html文件写入内容: <!DO...

    柴小智
  • angularjs 控制器、作用域、广播详解

    一、控制器 首先列出几种我们平常使用控制器时的几种误区: ? 我们知道angualrJs中一个控制器时可以对应不同的视图模板的,但这种实现方式存在的问题是: 如...

    柴小智
  • webpack学习(四)extract-text-webpack-plugin插件

    二、extract-text-webpack-plugin插件 从 bundle 中提取文本(CSS)到单独的文件 安装 npm install extract...

    柴小智
  • js三种引用方式

    2.行内使用方式,在标签内声明一下,比如a标记herf内嵌套JavaScript:

    十月梦想
  • 一个众人眼中“牛B”的项目是怎样越做越烂的

    最近在维护一个项目,接手之前好多运营同学说:“这个可是个牛B的项目,已经运行10来年了,基本满足了我们的运营需求,但是随着业务的调整,运营力度的加大,未来这个项...

    春哥大魔王
  • 巧用js替换某些不能替换的文字

    在运行某些程序时,作者为了保护版权,将版权文字进行了特殊处理,使得我们无法进行修改。

    繁花云
  • 打包优化实践(如何Code Spliting)

    开发环境中可使用 analyze-webpack-plugin 观察各模块的占用情况。以该项目为例:浏览器中输入 http://localhost:3000/a...

    牧云云
  • VS2017无法为MFC中的对话框创建类 解决办法

    在对话框模板上添加类是报错:SimpleScripts1033default.js下找不到default.js或.vbs

    idealclover
  • 3-9-10 Hot Module Replacement 热模块更新

    模块热替换(HMR - Hot Module Replacement)功能会在应用程序运行过程中替换、添加或删除模块,而无需重新加载整个页面。

    love丁酥酥
  • vuex - 简单使用步骤梳理,轻松掌握、附源码

    xing.org1^

扫码关注云+社区

领取腾讯云代金券

玩转腾讯云 有奖征文活动