欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Angularjs制作简单的路由功能demo

程序员文章站 2022-06-26 19:32:16
从官网下载了最新版本的angularjs 版本号:1.3.15 做一个简单的路由功能demo 首页:index.html

从官网下载了最新版本的angularjs 版本号:1.3.15

做一个简单的路由功能demo

首页:index.html

<!doctype html >

<html>
<head>
  <meta charset="utf-8" />
  <title>测试</title>
  <script src="./js/angular.min.js"></script>
  <script src="./js/angular-route.min.js"></script>
</head>
<body ng-app="myapp">
  <div ng-controller="textcontroller">
     <p>{{sometext}}</p>
  </div>
  <div ng-view></div>
</body>
  <script>
    var myapp = angular.module('myapp', ['ngroute']);
    myapp.controller('textcontroller', function ($scope) {
      $scope.sometext = '测试显示内容';
    });

    //路由
    function emailrouteconfig($routeprovider) {
      $routeprovider.
      when('/', {
        controller: listcontroller,
        templateurl: 'list.html'
      }).
      when('/view/:id', { //在id前面加一个冒号,从而制订了一个参数化url
        controller: detailcontroller,
        templateurl: 'detail.html'
      }).
      otherwise({
        redirectto: '/'
      });
    }

    myapp.config(emailrouteconfig);//配置我们的路由

    messages = [{
      id: 0, sender: "123456@qq.com", subject: "你好,这是一封邮件", date: "2015年4月13日", recipients: ['wifei@163.com'], message: "你好,我是xxx,这是发送给您的邮件。"
    }, {
      id: 1, sender: "123456@qq.com", subject: "你好,这是一封邮件", date: "2015年4月13日", recipients: ['wifei@163.com'], message: "你好,我是xxx,这是发送给您的邮件。"
    }, {
      id: 2, sender: "123456@qq.com", subject: "你好,这是一封邮件", date: "2015年4月13日", recipients: ['wifei@163.com'], message: "你好,我是xxx,这是发送给您的邮件。"
    }];

    function listcontroller($scope) {
      $scope.messages = messages;
    }

    function detailcontroller($scope,$routeparams) {
      $scope.message = messages[$routeparams.id];
    }
  </script>
</html>

列表页:list.html

<table>
  <tr>
    <td><strong>发件人</strong></td>
    <td><strong>内容</strong></td>
    <td><strong>日期</strong></td>
  </tr>
  <tr ng-repeat="message in messages">
    <td>{{message.sender}}</td>
    <td><a href="#/view/{{message.id}}">{{message.subject}}</a></td>
    <td>{{message.date}}</td>
  </tr>
</table>

详细页:detail.html

<div><strong>项目:</strong>{{message.subject}}</div>
<div><strong>发送者:</strong>{{message.sender}}</div>
<div><strong>日期:</strong>{{message.date}}</div>
<div>
  <strong>to:</strong>
  <span ng-repeat="recipient in message.recipients">
    {{recipient}}
  </span>
</div>
<div>{{message.message}}</div>
<a href="#/">回到列表</a>

以下是此次demo的坑:

1:新版的angularjs,引用路由功能,需要单独再引用 angular-route.js 文件

2:在定义module时也需要添加对'ngroute'的依赖
  angular.module('xxxx', ['ngroute'])

以上所述就是本文的全部内容了,希望大家能够喜欢。