求知 文章 文库 Lib 视频 iPerson 课程 认证 咨询 工具 讲座 Model Center   Code  
会员   
要资料
 
 
 

AngularJS教程
AngularJS快速入门
AngularJS环境设置
AngularJS MVC体系结构
AngularJS第一个应用程序
AngularJS指令
AngularJS表达式
AngularJS控制器
AngularJS过滤器
AngularJS表格
AngularJS HTML DOM
AngularJS模块
AngularJS表单
AngularJS包括
AngularJS Ajax
AngularJS视
AngularJS作用域
AngularJS服务
AngularJS依赖注入
AngularJS自定义指令
AngularJS国际化
 
 

AngularJS视图
949 次浏览
58次  

AngularJS支持通过在单个页面上的多个视图的单页应用。要做到这一点AngularJS提供ng-view 和 ng-template指令,以及 $routeProvider 服务。

ng-view

ng-view 标记只是简单地创建一个占位符,是一个相应的视图(HTML或ng-template视图),可以根据配置来放置。

使用

定义一个div与ng-view在主模块中。

<div ng-app="mainApp">
     ...
    <div ng-view></div>
    </div>  

ng-template

ng-template 指令是用来创建使用script标签的HTML视图。它包含一个用于由$routeProvider映射控制器视图“id”属性。

使用

定义类型作为主模块中 ng-template 的脚本块。

<div ng-app="mainApp">
    ...
    <script type="text/ng-template" id="addStudent.html">
        <h2> Add Student </h2>
           {{message}}
     </script>
    </div>  

$routeProvider

$routeProvider是组网址的配置,将它们映射相应的HTML页面或 ng-template,并附加一个控制器使用相同键的服务。

使用

定义类型作为主模块中 ng-template 的脚本块。

<div ng-app="mainApp">
     ...
     <script type="text/ng-template" id="addStudent.html">
        <h2> Add Student </h2>
           {{message}}
     </script>
    </div>  

使用

定义主模块的脚本块,并设置路由配置。

 var mainApp = angular.module("mainApp", ['ngRoute']);
                mainApp.config(['$routeProvider',
                     function($routeProvider) {
                           $routeProvider.
                             when('/addStudent', {
                              templateUrl: 'addStudent.html',
                              controller: 'AddStudentController'
                            }).
                            when('/viewStudents', {         
                                templateUrl: 'viewStudents.html',              
                                 controller: 'ViewStudentsController' 
                           }).
                            otherwise({ 
                               redirectTo: '/addStudent' 
                         }); 
             }]);

以下是在上面的例子中需要考虑的重要问题

  • $routeProvider被定义为使用关键字作为'$routeProvider“下mainApp模块的配置功能;
  • $routeProvider当定义了URL“/addStudent”映射到“addStudent.html”。 addStudent.html应存在于相同的路径主要的html 页面。如果htm页面没有定义,那么ng-template被id=“addStudent.html”使用。我们已经使用了ng-template;
  • “otherwise”是用来设置的默认视图;
  • “conlloer”是用来设置该视图对应的控制器;

例子

下面的例子将展示上述所有指令。

testAngularJS.html

<html>
    <head>
    <title>Angular JS Views</title>
    <script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.2.15/angular.min.js"></script> 
    <script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.2.25/angular-route.min.js"></script>
    </head>
    <body>
    <h2>AngularJS Sample Application</h2>
    <div ng-app="mainApp">
        <p><a href="#addStudent">Add Student</a></p>
        <p><a href="#viewStudents">View Students</a></p>
        <div ng-view></div>
        <script type="text/ng-template" id="addStudent.html">
           <h2> Add Student </h2>
           {{message}}
        </script>
        <script type="text/ng-template" id="viewStudents.html">
           <h2> View Students </h2>
	               {{message}}
        </script>
	     </div>   
    <script>   
     var mainApp = angular.module("mainApp", ['ngRoute']);
                mainApp.config(['$routeProvider',
           function($routeProvider) {
              $routeProvider.
                 when('/addStudent', {
                    templateUrl: 'addStudent.html',
                    controller: 'AddStudentController'
                 }).
                 when('/viewStudents', {
                    templateUrl: 'viewStudents.html',
                    controller: 'ViewStudentsController'
                 }).
                 otherwise({
                    redirectTo: '/addStudent'
                 });
           }]);
             mainApp.controller('AddStudentController', function($scope) {
              $scope.message = "This page will be used to display add student form";
           });
             mainApp.controller('ViewStudentsController', function($scope) {
                $scope.message = "This page will be used to display all the students";
           });
     </script>
  </body>
  </html>
 

输出

在Web浏览器中打开textAngularJS.html。看到结果如下:


您可以捐助,支持我们的公益事业。

1元 10元 50元





认证码: 验证码,看不清楚?请点击刷新验证码 必填



949 次浏览
58次
 捐助