AngularJS学习笔记(4)- AngularJS 控制器

AngularJS 控制器 控制 AngularJS 应用程序的数据
AngularJS 控制器是常规的 JavaScript 对象


AngularJS 控制器

AngularJS 应用程序被控制器控制。
ng-controller 指令定义了应用程序控制器。
控制器是 JavaScript 对象由标准的 JavaScript 对象的构造函数 创建

控制器的 $scope 是控制器所指向的应用程序 HTML 元素。($scope 的概念在 AngularJS 中非常重要。)

示例代码:

<body>
    <div ng-app="" ng-controller="personController">
        我的姓:<input type="text" ng-model="person.firstName">
        <br>
        我的名字:<input type="text" ng-model="person.lastName">
        <br>
        AngularJS 帮我们绑定的姓名:<br>
        {{person.firstName + " " + person.lastName}}
    </div>
    <script src="http://apps.bdimg.com/libs/angular.js/1.2.5/angular.js"></script>
    <script type="text/javascript">
        // 我开始写全局函数污染全局空间了 
        // 传入一个 $scope 对象
        function personController($scope){
            $scope.person = {
                firstName : "李",
                lastName : "威"
            };
        }
    </script>
</body>

实例效果:
这里写图片描述

实例讲解:
AngularJS 应用程序由 ng-app 定义。应用程序在 <div> 内运行
ng-controller 指令把控制器命名为 object
函数 personController 是一个标准的 JavaScript 对象的构造函数
控制器对象有一个属性:$scope.person。
person 对象有两个属性:firstName 和 lastName。
ng-model 指令绑定输入域到控制器的属性(firstName 和 lastName)。


下面我们简单聊聊控制器的属性:

控制器属性:

控制器也可以把函数作为对象属性。
也就是说定义属性的时候,可以定义一个函数(例子中是返回字符串)。
示例代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    <div ng-app="" ng-controller="personController">
        我的姓:<input type="text" ng-model="person.firstName">
        <br>
        我的名字:<input type="text" ng-model="person.lastName">
        <br>
        AngularJS 帮我们绑定的姓名:<br>
        {{person.showMyName()}}
    </div>
    <script src="http://apps.bdimg.com/libs/angular.js/1.2.5/angular.js"></script>
    <script type="text/javascript">
        // 我开始写全局函数污染全局空间了 
        // 传入一个 $scope 对象
        function personController($scope){
            $scope.person = {
                firstName : "李",
                lastName : "威",
                showMyName: function(){
                    var x;
                    x = $scope.person;
                    return x.firstName + "," + x.lastName;
                }
            };
        }
    </script>
</body>
</html>

注意事项:

  • 调用函数的时候,要带上括号;
  • 理解什么是 JavaScript 的构造函数。

控制器的方法:直接在控制器里面定义方法。注意调用的时候使用括号这个语法来调用。


外部文件中的控制器(这是最佳实践)

在大型的应用程序中,通常是把控制器存储在外部文件中。
只需要把 <script> 标签中的代码复制到 指定名称的外部 js 文件中即可。

下面我们看一个稍微复杂了一点点的控制器实例,融合了上面的内容,其实一点都不难:
这里写图片描述

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看REAdMe.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看REAdMe.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看READme.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 、 1资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看READmE.文件(md如有),本项目仅用作交流学习参考,请切勿用于商业用途。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通;、本 3项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看ReadmE.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 、资 1源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看READMe.m文件(如d有),本项目仅用作交流学习参考,请切勿用于商业用途。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值