当前位置: 移动技术网 > IT编程>脚本编程>AngularJs > AngularJS入门教程之多视图切换用法示例

AngularJS入门教程之多视图切换用法示例

2018年05月08日  | 移动技术网IT编程  | 我要评论

本文实例讲述了angularjs多视图切换用法。分享给大家供大家参考,具体如下:

在angularjs应用中,我们可以將html碎片写在一个单独的文件中,然后在其他页面中將该段碎片加载进来。如果有多个碎片文件,我们还可以在控制器中根据用户的操作动态的加载不同的碎片,从而达到切换视图的效果。

先来看看笔者写好的一个案例吧:

这两首词实际上是两个html碎片,分别写在page1.html和page2.html。下面是这两个文件的内容:

<!--page1.html内容-->
<div>
  <p>《南乡子·登京口北固亭有怀》</p>
  <p>何处望神州?满眼风光北固楼。千古兴亡多少事,悠悠,不尽长江滚滚流。</p>
  <p>年少万兜鍪,坐断东南战未休。天下英雄谁敌手,曹刘。生子当如孙仲谋。</p>
</div>

<!--page2.html内容-->
<div>
  <p>《蝶恋花》</p>
  <p>伫倚危楼风细细,望极春愁,黯黯生天际。草色烟光残照里,无言谁会凭阑意。</p>
  <p>拟把疏狂图一醉,对酒当歌,强乐还无味。衣带渐宽终不悔,为伊消得人憔悴。</p>
</div>

接下来我们看看如何实现这两个碎片的切换。

<!doctype html>
<html ng-app="routemod">
<head lang="en">
  <meta charset="utf-8">
  <script type="text/javascript" src="angular-1.3.0.14/angular.js"></script>
  <script type="text/javascript" src="angular-1.3.0.14/angular-route.js"></script>
  <link type="text/css" href="css/tutorial07.css" rel="stylesheet">
  <title>tutorial07.html</title>
</head>
<body>
  <header>
    header
  </header>
  <div id="content" ng-controller="multiviewcontroller">
    <div id="myview" ng-view="myview" ng-init="init()">
    </div>
    <div id="btndiv">
      <button ng-click="prepage()">上一页</button>
      <button ng-click="nextpage()">下一页</button>
    </div>
  </div>
  <footer>
    copyright:rongbo_j
  </footer>
  <script>
    var routemod = angular.module('routemod', ['ngroute']);
    routemod.config(['$routeprovider',function($routeprovider){
      $routeprovider.when('/1',{
        templateurl:'tutorial07/page1.html',
        controller:'multiviewcontroller'
      })
      .when('/2',{
        templateurl:'tutorial07/page2.html',
        controller:'multiviewcontroller'
      })
    }])
    routemod.controller("multiviewcontroller",function($scope,$log,$location){
      $scope.init = function () {
        $location.path("/1");
      }
      $scope.prepage = function () {
        $log.info("prepage");
        $location.path("/1");
      };
      $scope.nextpage = function () {
        $log.info("nextpage");
        $location.path("/2");
      };
    });
  </script>
</body>
</html>

这里我们需要用到angularjs的路由模块ngroute,模块代码封装在angular-route.js文件,和上节一样我们我们需要引入它。

<script type="text/javascript" src="angular-1.3.0.14/angular-route.js"></script>

然后将它注入到我们的模块中,代码如下:

var routemod = angular.module('routemod', ['ngroute']);

接下来的工作是配置html碎片的访问路径,我们需要调用模块的config方法来对$routeprovider服务进行配置,代码如下:

routemod.config(['$routeprovider',function($routeprovider){
  $routeprovider.when('/1',{
    templateurl:'tutorial07/page1.html',
    controller:'multiviewcontroller'
  })
  .when('/2',{
    templateurl:'tutorial07/page2.html',
    controller:'multiviewcontroller'
  })
}])

我们通过ng-view指令定义了一个视图,在控制器中调用$location.path()方法来指定在该视图中加载哪一个碎片

angularjs源码可点击此处。

希望本文所述对大家angularjs程序设计有所帮助。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网