源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

详解AngularJS中的作用域

  • 时间:2022-09-20 11:33 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:详解AngularJS中的作用域
 范围扮演其视图连接控制器的角色一个特殊的JavaScript对象。范围包含了模型数据。在控制器,模型数据通过$scope对象访问。
<script>
   var mainApp = angular.module("mainApp", []);

   mainApp.controller("shapeController", function($scope) {
     $scope.message = "In shape controller";
     $scope.type = "Shape";
   });
</script>

以下是在上面的例子中需要考虑的重要问题。 [list] [*]    $scope被作为第一个参数在其构造器确定指标到控制器。[/*] [*]    $scope.message 和 $scope.type 是它们在HTML页面中所用的模型。[/*] [*]    我们已经设置模型的值将反映应用程序模块的控制器shapeController中。[/*] [*]    我们可以在$scope定义函数功能。[/*] [/list] [b]继承范围[/b] 范围是特定的控制器。如果我们定义嵌套的控制器,然后控制器子将继承其父控制的范围。
<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>

以下是在上面的例子中需要考虑的重要问题。 [list] [*]    我们在shapeController设定模型的值。[/*] [*]    我们覆盖的子控制器circleController消息。当“消息”内的控制器circleController的模块使用时,将用于重写的消息。[/*] [/list] [b]例子[/b] 下面的例子将展示上述所有指令。 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://ajax.googleapis.com/ajax/libs/angularjs/1.2.15/angular.min.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。看到结果如下。 [img]http://files.jb51.net/file_images/article/201506/2015617110218233.jpg?201551711228[/img]
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部