这个AngularJS“HelloWorld”应用程序如何运作?关于Angular如何实现MVC模式的一些疑问

时间:2015-11-03 19:50:30

标签: javascript angularjs angularjs-scope javascript-framework

我在 AngularJS 中绝对是新手,我正在关注一个展示AngularJS应用程序第一个示例的课程,我对这究竟是如何工作有一些疑问。

所以它由这两个文件组成:

1) index.htm

<!DOCTYPE html>
<html lang="en-us" ng-app="angularApp">
    <head>
        <title>Introduction to AngularJS</title>
        <meta http-equiv="X-UA-Compatible" content="IE=Edge">
        <meta charset="UTF-8">

        <!-- load bootstrap and fontawesome via CDN -->
        <link rel="stylesheet" href="//netdna.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap.min.css" />
        <style>
            html, body
            {
                font-size: 1.1em;
            }
        </style>

        <!-- load angular via CDN -->
        <script src="//code.angularjs.org/1.3.0-rc.1/angular.min.js"></script>
        <script src="app.js"></script>
    </head>
    <body>

        <header>
            <nav class="navbar navbar-default">
            <div class="container">
                <div class="navbar-header">
                    <a class="navbar-brand" href="/">AngularJS</a>
                </div>

                <ul class="nav navbar-nav navbar-right">
                    <li><a href="#"><i class="fa fa-home"></i> Home</a></li>
                </ul>
            </div>
            </nav>
        </header>

        <div class="container">

            <!-- This div and its content is the view associated to the 'mainController': -->
            <div ng-controller="mainController">

                <h1>Hello world!</h1>

            </div>

        </div>

    </body>
</html>

2) app.js

/* MODULE: one signgle object in the global namespace.
           Everything insise the element having ng-app="angularApp" custom attribute is connected to the angularApp variable into the
           global namespace
*/
var angularApp = angular.module('angularApp', []);

// CONTROLLERS
angularApp.controller('mainController', ['$scope', function ($scope) {

}]);

所以我对它究竟是如何工作有一些怀疑。

从我所理解的 app.js 文件中,定义了一个模块,该模块基本上是在我的应用程序的全局命名空间中定义的单个对象。但究竟什么代表AngularJS中的模块?我来自Spring MVC框架(以及其他一些经典的MVC),其中模块表示必须显示在视图中的数据。

在Angular中究竟代表什么?

所以根据我的理解,这个模块与整个 index.htm 页面绑定,因为在HTML中声明了:

<html lang="en-us" ng-app="angularApp">

所以我认为html页面上的 ng-app =“angularApp”意味着 angularApp 模块与索引中发生的事情有关。 html 页面。这是我的推理是正确的还是错的?

然后在 app.js 文件中,还定义了控制器

// CONTROLLERS
angularApp.controller('mainController', ['$scope', function ($scope) {

}]);

这个 mainController 控制器( mainController 控制器名称?)是在 angularApp 模型对象上定义的。

好的,我不是用JavaScript,但我认为它的工作原理如下:

mainController 变量是一个JavaScript对象,在前一行中我添加了一个名为 mainController 的控制器字段,控制器逻辑由与此相关联的函数实现字段(因为在JavaScript中,函数可以是对象的字段)。

我的推理是正确还是我遗漏了控制器声明?

另一个疑问与使用'$ scope'变量有关。究竟意味着什么?语法的含义是什么 ['$ scope',函数($ scope){.... CONTROLLER LOGIC ....}]

此控制器与特定视图相关联,该视图由 index.htm 页面的特定部分表示,此页面为:

        <!-- This div and its content is the view associated to the 'mainController': -->
        <div ng-controller="mainController">

            <h1>Hello world!</h1>

        </div>

这对我产生了一些困惑,因为它看起来与我在其他Java MVC实现中看到的完全不同。

与Java MVC实现不同,在AngularJS中,视图不是整个页面(在Java中可能是.jsp页面),但它是由 ng绑定到特定控制器的HTML页面的一部分。 -controller =“mainController”自定义属性。这是真的吗?

与Java MVC实现不同,在AngularJS(或前面的示例)中,模型不仅是包含要显示到视图中的增量字段的对象,而且它是应用程序的全局命名空间中的对象。与控制器(作为模型的字段)相关联,以对指定视图执行操作。

我的推理是正确的还是我错过了什么?

1 个答案:

答案 0 :(得分:1)

一切都很好,您的控制器和您的视图都可以。 下一步,您需要立即创建一个绑定服务器API的服务,并像您的模型一样工作。

事实上,角度“控制器”可以像模型一样工作,但如果你只想在那里做控制器/监听器的事情,你需要创建一个真实的服务:

为例:

app.service('ContactService', function () {

//'var' act like private
var contacts = [{
    id: 0,
    name: 'hello world'
}];

//'this' act like public (cool for java dev, you should feel like home :) )
this.save = function (contact) {
    //here connect to your api or stay offline
}

this.get = function (id) {

}

this.delete = function (id) {

}

this.list = function () {
    return contacts;
}
});

你的控制器

angularApp.controller('mainController', ['$scope','ContactService', function ($scope,ContactService) {
    $scope.contact = ContactService.get(0)
}]);

视图

    <div ng-controller="mainController">

        <h1>{{contact.name}}</h1>

    </div>