欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

AngularJS入门教程之MVC架构实例分析

程序员文章站 2022-06-02 10:29:46
本文实例讲述了angularjs的mvc架构。分享给大家供大家参考,具体如下: mvc应用程序架构最早于1970年起源于smalltalk语言,后来在桌面应用程序开发中使...

本文实例讲述了angularjs的mvc架构。分享给大家供大家参考,具体如下:

mvc应用程序架构最早于1970年起源于smalltalk语言,后来在桌面应用程序开发中使用较为广泛,如今在web开发中也非常流行。mvc的核心思想是將数据的管理(model)、业务逻辑控制(controller)和数据的展示(view)分离开来,使程序的逻辑性和可维护性更强。

对于angularjs应用来说,视图(view)是dom(文档对象模型),你可以理解为就是html页面。控制器(controller)是一个用户自定义的javascript类。模型数据(model)存储在对象的属性中。

我们来看下面的代码:

<!doctype html>
<html ng-app>
<head lang="en">
 <meta charset="utf-8">
 <script type="text/javascript" src="angular-1.3.0.14/angular.js"></script>
 <title>tutorial03</title>
</head>
<body>
<div ng-controller="usercontroller">
 用户名:<input type="text" ng-model="name" placeholder="用户名"/>
 密码:<input type="password" ng-model="pword" placeholder="密码"/>
 <button ng-click="login()">提交</button>
 <p>您输入的用户名:{{name}}</p>
 <p>您输入的密码:{{pword}}</p>
</div>
<script>
 function usercontroller ($scope,$log)
 {
  $scope.name="admin";
  $scope.pword="123456";
  $log.info( $scope.name);
  $log.info( $scope.pword);
  $scope.login = function()
  {
   alert("登录");
  }
 }
</script>
</body>
</html>

我们在前面一篇《angularjs入门教程之数据绑定用法示例》代码的基础上进行修改,我们通过ng-controller指令声明一个控制器,名称为usercontroller,它所在的div开始标签和结束标签之间的部分都由该控制器来管理。

function usercontroller...为控制器定义部分,这里我们依靠angularjs依赖注入系统以参数的形式向控制器中注入$scope和$log对象。$scope为模型数据对象,前面有提到过,ng-model的作用就是为$scope对象添加一个属性和表单元素绑定。$log对象用于在浏览器控制台中输出调试信息。

在控制器中可以做一些初始化工作,例如这里我们將用户名和密码文本框中的内容初始化为”admin”,”123456”。还可用于事件处理,我们通过ng-click指令声明按钮的点击事件处理函数为login(),在控制器中通过$scope.login = function()...进行事件绑定。

在浏览器中运行可以看到效果如下:

AngularJS入门教程之MVC架构实例分析

页面加载时文本框中内容被初始化,点击提交弹出对话框。

angularjs的控制器的作用域仅限于ng-controller所在的元素开始标签和结束标签之间的部分,为了证明这个结论我们再增加一个控制器,代码如下:

<!doctype html>
<html ng-app>
<head lang="en">
 <meta charset="utf-8">
 <script type="text/javascript" src="angular-1.3.0.14/angular.js"></script>
 <title>tutorial03</title>
</head>
<body>
<div ng-controller="usercontroller" style="border:#ccc solid 1px;">
 用户名:<input type="text" ng-model="name" placeholder="用户名"/>
 密码:<input type="password" ng-model="pword" placeholder="密码"/>
 <button ng-click="login()">提交</button>
 <p>您输入的用户名:{{name}}</p>
 <p>您输入的密码:{{pword}}</p>
</div>
<br/>
<div ng-controller="infocontoller" style="border:#ccc solid 1px;">
 个人爱好:<input type="text" ng-model="love" placeholder="个人爱好"/>
 <p>您输入的个人爱好:{{love}}</p>
</div>
<script>
 function usercontroller($scope,$log)
 {
  $scope.name="admin";
  $scope.pword="123456";
  $scope.login = function()
  {
   alert("登录");
  }
 }
 function infocontoller($scope,$log)
 {
  $scope.love="足球";
  $log.info($scope.name);
  $log.info($scope.pword);
  $log.info($scope.love);
 }
</script>
</body>
</html>

由于name和pword不是在infocontoller控制器中定义的,我们在控制台中输出$scope.name和$scope.pword显示为undefined.

AngularJS入门教程之MVC架构实例分析

angularjs源码可点击此处。

希望本文所述对大家angularjs程序设计有所帮助。