AngularJs轻松入门(三)MVC架构
来源:互联网 发布:sql 数据库链接 编辑:程序博客网 时间:2024/05/02 04:41
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>
我们在上一节代码的基础上进行修改,我们通过ng-controller指令声明一个控制器,名称为UserController,它所在的div开始标签和结束标签之间的部分都由该控制器来管理。
function UserController...
为控制器定义部分,这里我们依靠AngularJs依赖注入系统以参数的形式向控制器中注入$scope
和$log
对象。$scope
为模型数据对象,上一节有提到过,ng-model的作用就是为$scope
对象添加一个属性和表单元素绑定。$log
对象用于在浏览器控制台中输出调试信息。
在控制器中可以做一些初始化工作,例如这里我们將用户名和密码文本框中的内容初始化为”admin”,”123456”。还可用于事件处理,我们通过ng-click指令声明按钮的点击事件处理函数为login(),在控制器中通过$scope.login = function()...
进行事件绑定。
在浏览器中运行可以看到效果如下:
页面加载时文本框中内容被初始化,点击提交弹出对话框。
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轻松入门(二)数据绑定
- AngularJs轻松入门(四)模块化
- AngularJs轻松入门(五)过滤器
- AngularJs轻松入门(六)表单校验
- AngularJs轻松入门(八)Cookies读写
- AngularJs轻松入门
- AngularJS入门-(2)MVC体系结构
- AngularJs轻松入门(一)创建第一个应用
- AngularJs轻松入门(七)多视图切换
- AngularJs轻松入门(九)与服务器交互
- AngularJs轻松入门(一)创建第一个应用
- 轻松入门easyui(三)效果展示
- AngularJs轻松入门源码托管至Github
- AngularJs轻松入门源码托管至Github
- PHP MVC基础架构(三)
- SAX轻松入门(三)--SAX过滤器(filter)
- SQL练习题
- 进程模型与线程模型
- Win7下VC++6.0打开文件报错导致其崩溃的解决办法
- Win7和VS2013上使用Intel的TBB
- linux 中信号
- AngularJs轻松入门(三)MVC架构
- iOS开发笔记7——Xcode 6中添加预编译pch文件
- 10 java集合框架
- 在Eclipse中查看JDK类库的源代码!!!
- Hello Kiki(hdu3579+不互质的中国剩余定理)
- android环境下摄像头数据采集及显示
- oracle中修改表名
- 用Python和Pygame写游戏-从入门到精通(22)
- 「HD_ACM」A+B for Input-Output Practice (III)