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


Posted in Javascript onNovember 01, 2016

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

MVC应用程序架构最早于1970年起源于Smalltalk语言,后来在桌面应用程序开发中使用较为广泛,如今在WEB开发中也非常流行。MVC的核心思想是?⑹?莸墓芾恚?odel)、业务逻辑控制(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对象用于在浏览器控制台中输出调试信息。

在控制器中可以做一些初始化工作,例如这里我们?⒂没??兔苈胛谋究蛑械哪谌莩跏蓟???dmin”,”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程序设计有所帮助。

Javascript 相关文章推荐
JS中confirm,alert,prompt函数区别分析
Jan 17 Javascript
用jquery和json从后台获得数据集的代码
Nov 07 Javascript
Dom 学习总结以及实例的使用介绍
Apr 24 Javascript
探讨jQuery的ajax使用场景(c#)
Dec 03 Javascript
jQuery中queue()方法用法实例
Dec 29 Javascript
js日期范围初始化得到前一个月日期的方法
May 05 Javascript
JS实现可关闭的对联广告效果代码
Sep 14 Javascript
js封装成插件_Canvas统计图插件编写实例
Sep 12 Javascript
使用jQuery动态设置单选框的选中效果
Dec 06 jQuery
Nuxt使用Vuex的方法示例
Sep 06 Javascript
原生JavaScript实现购物车
Jan 10 Javascript
vue动态设置路由权限的主要思路
Jan 13 Vue.js
bootstrap table复杂操作代码
Nov 01 #Javascript
bootstrap flask登录页面编写实例
Nov 01 #Javascript
JS弹出窗口的运用与技巧大全
Nov 01 #Javascript
Bootstrap树形菜单插件TreeView.js使用方法详解
Nov 01 #Javascript
JS实现快速的导航下拉菜单动画效果附源码下载
Nov 01 #Javascript
AngularJS入门教程之数据绑定用法示例
Nov 01 #Javascript
jQuery动态生成Bootstrap表格
Nov 01 #Javascript
You might like
用PHP开发GUI
2006/10/09 PHP
php 服务器调试 Zend Debugger 的安装教程
2009/09/25 PHP
PHP使用缓存即时输出内容(output buffering)的方法
2015/08/03 PHP
PHP设计模式之状态模式定义与用法详解
2018/04/02 PHP
PHP中number_format()函数的用法讲解
2019/04/08 PHP
Linux下安装Memcached服务器和客户端与PHP使用示例
2019/04/15 PHP
jQuery获取和设置表单元素的方法
2014/02/14 Javascript
Egret引擎开发指南之视觉编程
2014/09/03 Javascript
javascript实现控制浏览器全屏
2015/03/30 Javascript
js+cookies实现悬浮购物车的方法
2015/05/25 Javascript
在JavaScript中处理字符串之fontcolor()方法的使用
2015/06/08 Javascript
高效的jquery数字滚动特效
2015/12/17 Javascript
使用JavaScript实现弹出层效果的简单实例
2016/05/31 Javascript
AngularJS $injector 依赖注入详解
2016/09/14 Javascript
Node.js的特点详解
2017/02/03 Javascript
使用gulp搭建本地服务器并实现模拟ajax
2017/04/05 Javascript
vue组件之Alert的实现代码
2017/10/17 Javascript
浅谈Vue组件及组件的注册方法
2018/08/24 Javascript
JavaScript页面加载事件实例讲解
2019/09/01 Javascript
npx create-react-app xxx创建项目报错的解决办法
2020/02/17 Javascript
jquery实现拖拽小方块效果
2020/12/10 jQuery
Mac下Supervisor进程监控管理工具的安装与配置
2014/12/16 Python
Python按行读取文件的实现方法【小文件和大文件读取】
2016/09/19 Python
Python网络编程之TCP与UDP协议套接字用法示例
2018/02/02 Python
Python从数据库读取大量数据批量写入文件的方法
2018/12/10 Python
python使用zip将list转为json的方法
2018/12/31 Python
Python 内置函数globals()和locals()对比详解
2019/12/23 Python
Python 面向对象静态方法、类方法、属性方法知识点小结
2020/03/09 Python
解决python的空格和tab混淆而报错的问题
2021/02/26 Python
英国顶级珠宝品牌之家:John Greed
2018/06/09 全球购物
应届生求职推荐信
2013/10/28 职场文书
加工操作管理制度
2014/01/19 职场文书
关爱残疾人演讲稿
2014/05/24 职场文书
房屋分割离婚协议书范本
2014/12/01 职场文书
公司行政管理制度范本
2015/08/05 职场文书
td 内容自动换行 table表格td设置宽度后文字太多自动换行
2022/12/24 HTML / CSS