返回介绍

业务处理

发布于 2024-12-24 22:41:42 字数 4235 浏览 0 评论 0 收藏 0

9.3. 业务处理

简单来说,当一个锚点路由定义被匹配时,会根据模板生成一个 `$scope` ,同时相应的一个 controller 就会被触发。最后模板的结果会被填充到 `ng-view` 中去。

从上面的例子中可以看到,最直接的方式,我们可以在模板中双向绑定数据,而数据的来源,在 controller 中控制。在 controller 中,又可以使用到像 `$scope` , `$routeParams` 这些服务。

这里先提一下另外一种与锚点路由相关的服务, `$route` 。这个服务里锚点路由在定义时,及匹配过程中的信息。比如我们搞怪一下:

  angular.module('ngView', [],
    function($routeProvider){
      $routeProvider.when('/a',
        {
          template: '{ { title } }',
          controller: function($scope){
            $scope.title = 'a';
          }
        }
      );

      $routeProvider.when('/b',
        {
          template: '{ { title } }',
          controller: function($scope, $route){
            console.log($route);
            $route.routes['/a'].controller($scope);
          }
        }
      );
    }
  );

回到锚点定义的业务处理中来。我们可以以字符串形式写模板,也可以直接引用外部文件作为模板:

  angular.module('ngView', [],
    function($routeProvider){
      $routeProvider.when('/test',
        {
          templateUrl: 'tpl.html',
          controller: function($scope){
            $scope.title = 'a';
          }
        }
      );
    }
  );

`tpl.html` 中的内容是:

  { { title } }

这样的话,模板可以预定义,也可以很复杂了。

现在暂时忘了模板吧,因为前面提到的,当前 `ng-view` 不能有多个的限制,模板的渲染机制局限性还是很大的。不过,反正会触发一个 controller ,那么在函数当中我们可以尽量地干自己喜欢的事:

  angular.module('ngView', [],
    function($routeProvider){
      $routeProvider.when('/test',
        {
          template: '{ {} }',
          controller: function(){
            $('div').first().html('<b>OK</b>');
          }
        }
      );
    }
  );

那个空的 `template` 不能省,否则 controller 不会被触发。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文