• 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>

    我们在上一节代码的基础上进行修改,我们通过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.

    这里写图片描述

  • 相关阅读:
    CentOS中文件夹基本操作命令
    Apache和Nginx下禁止访问特定的目录或文件
    自适应网页设计(Responsive Web Design)
    使用Google Https搜索
    AMD 3600+ X2 CPU配合昂达A69T主板超频教程
    dedecms上传图片相对路径改成绝对路径方法
    安装ecshop默认安装后的错误解决方案
    动态加载JS脚本的4种方法
    Java虚拟机(二)对象的创建与OOP-Klass模型
    Android系统启动流程(四)Launcher启动过程与系统启动流程
  • 原文地址:https://www.cnblogs.com/lanzhi/p/6468910.html
Copyright © 2020-2023  润新知