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

AngularJS ng-repeat指令及Ajax的应用实例分析

程序员文章站 2022-05-14 19:55:31
本文实例讲述了angularjs ng-repeat指令及ajax的应用。分享给大家供大家参考,具体如下: ng-repeat 指令用于循环输出指定次数的 html 元素...

本文实例讲述了angularjs ng-repeat指令及ajax的应用。分享给大家供大家参考,具体如下:

ng-repeat 指令用于循环输出指定次数的 html 元素。集合必须是数组或对象。

定义:

<element ng-repeat="expression"></element>

说明:experssion表达式定义了如何循环集合。常用的如:x in records

下面通过一个例子,来说明ng-repeat如何绘制一个表格:

<div ng-app='mainapp' ng-controller='studentcontroller'>
  <table border="0">
    <tr>
      <td>姓</td>
      <td><input type="text" ng-model='student.firstname'></td>
    </tr>
    <tr>
      <td>名</td>
      <td><input type="text" ng-model='student.lastname'></td>
    </tr>
    <tr>
      <td>名字</td>
      <td>{{student.fullname()}}</td>
    </tr>
    <tr>
      <td>科目</td>
      <td>
        <table>
          <tr>
            <th>名字</th>
            <th>标记</th>
          </tr>
          <tr ng-repeat='sub in student.subjects'>
            <td>{{sub.name}}</td>
            <td>{{sub.marks}}</td>
          </tr>
        </table>
      </td>
    </tr>
  </table>
</div>

表可以使用css样式设置样式。

<style>
  table, th , td {
    border: 1px solid grey;
    border-collapse: collapse;
    padding: 5px;
  }
  table tr:nth-child(odd) {
    background-color: #f2f2f2;
  }
  table tr:nth-child(even) {
    background-color: #ffffff;
  }
</style>

利用angularjs的ng-repeat指令绘制表格:

<script>
  var mainapp=angular.module('mainapp',[]); //定义一个名为mainapp的模块
  mainapp.controller('studentcontroller',function($scope){
    $scope.student={
      firstname:'聂',
      lastname:'鹏飞',
      subjects:[
      {name:'物理',marks:73},
          {name:'化学',marks:90},
          {name:'数学',marks:68},
          {name:'英文',marks:85},
          {name:'生物',marks:77},
      ],
      fullname:function(){
        var studentobject;
        studentobject = $scope.student;
        return studentobject.firstname+' '+studentobject.lastname;
      }
    };
  });
</script>

效果:

AngularJS ng-repeat指令及Ajax的应用实例分析

上面例子表格中展示的数据也可以通过ajax请求从服务器中获取,然后利用ng-repeat指令插入到页面中,具体实现见下面代码:

<html>
<head>
<title>angular js controller</title>
<script src="angularjs/angular-1.3.0/angular.min.js"></script>
<style>
  table, th , td {
    border: 1px solid grey;
    border-collapse: collapse;
    padding: 5px;
  }
  table tr:nth-child(odd) {
    background-color: #f2f2f2;
  }
  table tr:nth-child(even) {
    background-color: #ffffff;
  }
</style>
</head>
<body>
  <h2>angularjs 表格应用示例</h2>
  <div ng-app='mainapp' ng-controller='studentcontroller'>
    <table border="0">
      <tr>
        <td>姓</td>
        <td><input type="text" ng-model='student.firstname'></td>
      </tr>
      <tr>
        <td>名</td>
        <td><input type="text" ng-model='student.lastname'></td>
      </tr>
      <tr>
        <td>名字</td>
        <td>{{student.fullname()}}</td>
      </tr>
      <tr>
        <td>科目</td>
        <td>
          <table>
            <tr>
              <th>名字</th>
              <th>标记</th>
            </tr>
            <tr ng-repeat='sub in student.subjects'>
              <td>{{sub.name}}</td>
              <td>{{sub.marks}}</td>
            </tr>
          </table>
        </td>
      </tr>
    </table>
  </div>
  <script>
    var mainapp=angular.module('mainapp',[]);
    mainapp.controller('studentcontroller',function($scope,$http){
      $scope.student={
        firstname:'聂',
        lastname:'鹏飞',
        fullname:function(){
          var studentobject;
          studentobject = $scope.student;
          return studentobject.firstname+' '+studentobject.lastname;
        },
      };
      var url="data.txt";
      $http.post(url).success(function(response){
        $scope.student.subjects=response;
      })
    });
  </script>
</body>
</html>

说明:需要放在服务器环境中运行

更多关于angularjs相关内容感兴趣的读者可查看本站专题:《angularjs指令操作技巧总结》、《angularjs入门与进阶教程》及《angularjs mvc架构总结

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