我在 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(或前面的示例)中,模型不仅是包含要显示到视图中的增量字段的对象,而且它是应用程序的全局命名空间中的对象。与控制器(作为模型的字段)相关联,以对指定视图执行操作。
我的推理是正确的还是我错过了什么?
答案 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>