详解AngularJS中的作用域
- 作者: 汪_辉煌
- 来源: 51数据库
- 2021-07-08
范围扮演其视图连接控制器的角色一个特殊的javascript对象。范围包含了模型数据。在控制器,模型数据通过$scope对象访问。
<script>
var mainapp = angular.module("mainapp", []);
mainapp.controller("shapecontroller", function($scope) {
$scope.message = "in shape controller";
$scope.type = "shape";
});
</script>
以下是在上面的例子中需要考虑的重要问题。
- $scope被作为第一个参数在其构造器确定指标到控制器。
- $scope.message 和 $scope.type 是它们在html页面中所用的模型。
- 我们已经设置模型的值将反映应用程序模块的控制器shapecontroller中。
- 我们可以在$scope定义函数功能。
继承范围
范围是特定的控制器。如果我们定义嵌套的控制器,然后控制器子将继承其父控制的范围。
<script>
var mainapp = angular.module("mainapp", []);
mainapp.controller("shapecontroller", function($scope) {
$scope.message = "in shape controller";
$scope.type = "shape";
});
mainapp.controller("circlecontroller", function($scope) {
$scope.message = "in circle controller";
});
</script>
以下是在上面的例子中需要考虑的重要问题。
- 我们在shapecontroller设定模型的值。
- 我们覆盖的子控制器circlecontroller消息。当“消息”内的控制器circlecontroller的模块使用时,将用于重写的消息。
例子
下面的例子将展示上述所有指令。
testangularjs.html
<html>
<head>
<title>angular js forms</title>
</head>
<body>
<h2>angularjs sample application</h2>
<div ng-app="mainapp" ng-controller="shapecontroller">
<p>{{message}} <br/> {{type}} </p>
<div ng-controller="circlecontroller">
<p>{{message}} <br/> {{type}} </p>
</div>
<div ng-controller="squarecontroller">
<p>{{message}} <br/> {{type}} </p>
</div>
</div>
<script src="http://www.51sjk.com/Upload/Articles/1/0/261/261623_20210702001039375.js"></script>
<script>
var mainapp = angular.module("mainapp", []);
mainapp.controller("shapecontroller", function($scope) {
$scope.message = "in shape controller";
$scope.type = "shape";
});
mainapp.controller("circlecontroller", function($scope) {
$scope.message = "in circle controller";
});
mainapp.controller("squarecontroller", function($scope) {
$scope.message = "in square controller";
$scope.type = "square";
});
</script>
</body>
</html>
结果
在web浏览器打开textangularjs.html。看到结果如下。

推荐阅读
热点文章
Angular中响应式表单的三种更新值方法详析
7
Angularjs实现下拉框联动的示例代码
7
详解AngularJS跨页面传值(ui-router)
2
详解AngularJS1.x学习directive 中‘& ’‘=’ ‘@’符号的区别使用
3
angular2路由切换改变页面title的示例代码
4
Angular2 组件间通过@Input @Output通讯示例
5
Angularjs中ng-repeat的简单实例
3
AngularJS 中ui-view传参的实例详解
4
浅谈Angular路由守卫
4
详解基于Angular4+ server render(服务端渲染)开发教程
4
