AngularJS表格基础知识笔记,如何实现动态排序与分页?

AngularJS 作为一款经典的前端 JavaScript 框架,其核心特性之一就是通过数据绑定简化动态页面的开发,在处理数据展示时,表格是常用的组件,AngularJS 提供了强大的指令来动态渲染和操作表格数据,下面将详细介绍 AngularJS 中表格相关的核心知识点。

AngularJS表格基础知识笔记,如何实现动态排序与分页?

基础表格渲染:ng-repeat 指令

在 AngularJS 中,ng-repeat 是最基础的数据循环指令,可用于动态生成表格行,假设有一个包含用户数据的数组 $scope.users,可通过以下方式渲染表格:

<table border="1">
  <thead>
    <tr>
      <th>ID</th>
      <th>姓名</th>
      <th>年龄</th>
    </tr>
  </thead>
  <tbody>
    <tr ng-repeat="user in users">
      <td>{{user.id}}</td>
      <td>{{user.name}}</td>
      <td>{{user.age}}</td>
    </tr>
  </tbody>
</table>

关键点

  • ng-repeat="user in users" 会遍历 $scope.users 数组,为每个元素创建一个 <tr> 元素。
  • 使用 {{user.property}} 绑定数据到单元格,AngularJS 会自动更新视图。

表格排序功能

实现动态排序需要结合 ng-repeatorderBy 过滤器,并通过变量控制排序字段和顺序。

<table>
  <thead>
    <tr>
      <th ng-click="sortBy('id')">ID <span ng-show="sortKey === 'id'">{{reverse ? '↑' : '↓'}}</span></th>
      <th ng-click="sortBy('name')">姓名 <span ng-show="sortKey === 'name'">{{reverse ? '↑' : '↓'}}</span></th>
      <th ng-click="sortBy('age')">年龄 <span ng-show="sortKey === 'age'">{{reverse ? '↑' : '↓'}}</span></th>
    </tr>
  </thead>
  <tbody>
    <tr ng-repeat="user in users | orderBy:sortKey:reverse">
      <td>{{user.id}}</td>
      <td>{{user.name}}</td>
      <td>{{user.age}}</td>
    </tr>
  </tbody>
</table>

控制器逻辑

$scope.sortKey = 'id'; // 默认排序字段
$scope.reverse = false; // 默认升序
$scope.sortBy = function(key) {
  if ($scope.sortKey === key) {
    $scope.reverse = !$scope.reverse; // 切换排序顺序
  } else {
    $scope.sortKey = key;
    $scope.reverse = false;
  }
};

关键点

  • orderBy:sortKey:reverse 中,sortKey 为排序字段,reverse 为布尔值(true 降序,false 升序)。
  • 点击表头时调用 sortBy 方法,动态更新 sortKeyreverse 实现排序。

表格过滤与搜索

通过 filter 过滤器可实现表格数据的实时搜索,通常结合输入框的 ng-model 指令。

AngularJS表格基础知识笔记,如何实现动态排序与分页?

<input type="text" ng-model="searchText" placeholder="搜索姓名或年龄">
<table>
  <thead>
    <tr>
      <th>姓名</th>
      <th>年龄</th>
    </tr>
  </thead>
  <tbody>
    <tr ng-repeat="user in users | filter:searchText">
      <td>{{user.name}}</td>
      <td>{{user.age}}</td>
    </tr>
  </tbody>
</table>

关键点

  • filter:searchText 会根据输入框的值过滤 $scope.users 数组,支持模糊匹配。
  • 若需指定过滤字段(如仅搜索姓名),可改为 filter:{name:searchText}

表格分页功能

分页需要手动计算当前页的数据范围,结合 limitTonumber 过滤器实现。

<div>
  每页显示:
  <select ng-model="pageSize">
    <option value="5">5</option>
    <option value="10">10</option>
  </select>
</div>
<table>
  <tbody>
    <tr ng-repeat="user in users | limitTo:pageSize: (currentPage-1)*pageSize">
      <td>{{user.name}}</td>
      <td>{{user.age}}</td>
    </tr>
  </tbody>
</table>
<div>
  <button ng-disabled="currentPage === 1" ng-click="currentPage--">上一页</button>
  <span>第 {{currentPage}} 页 / 共 {{Math.ceil(users.length/pageSize)}} 页</span>
  <button ng-disabled="currentPage >= Math.ceil(users.length/pageSize)" ng-click="currentPage++">下一页</button>
</div>

控制器逻辑

$scope.currentPage = 1; // 当前页码
$scope.pageSize = 5; // 每页条数

关键点

  • limitTo:pageSize: (currentPage-1)*pageSize 中,第一个参数为每页条数,第二个参数为起始索引。
  • 通过 currentPagepageSize 计算总页数,并控制分页按钮的禁用状态。

表格样式与条件渲染

结合 ng-classng-if 可实现动态样式和条件渲染,为年龄超过 30 的行添加高亮样式:

<tr ng-repeat="user in users" ng-class="{'highlight': user.age > 30}">
  <td>{{user.name}}</td>
  <td>{{user.age}}</td>
</tr>

CSS 样式

AngularJS表格基础知识笔记,如何实现动态排序与分页?

.highlight {
  background-color: #ffeb3b;
}

关键点

  • ng-class 支持对象语法,键为 CSS 类名,值为布尔表达式,条件为 true 时添加类名。
  • ng-if 可用于根据条件渲染整个行或单元格(如 ng-if="user.age >= 18" 显示成年标识)。

表格数据操作

可通过按钮实现数据的增删改,例如添加新用户:

<input type="text" ng-model="newUser.name" placeholder="姓名">
<input type="number" ng-model="newUser.age" placeholder="年龄">
<button ng-click="addUser()">添加</button>
<tr ng-repeat="user in users">
  <td>{{user.name}}</td>
  <td>{{user.age}}</td>
  <td><button ng-click="deleteUser($index)">删除</button></td>
</tr>

控制器逻辑

$scope.newUser = {};
$scope.addUser = function() {
  $scope.users.push(angular.copy($scope.newUser));
  $scope.newUser = {}; // 清空输入
};
$scope.deleteUser = function(index) {
  $scope.users.splice(index, 1);
};

关键点

  • 使用 angular.copy() 避免引用类型数据导致的问题。
  • 删除时通过 $index 获取当前行的索引,splice() 方法移除数组元素。

AngularJS 通过 ng-repeat、过滤器(orderByfilterlimitTo)和指令(ng-classng-modelng-click)等特性,实现了表格的动态渲染、排序、搜索、分页及数据操作,掌握这些基础知识点,能够高效构建功能完善的表格组件,为复杂的数据展示场景打下坚实基础,在实际开发中,还需结合性能优化(如大数据量时使用分页)和用户体验设计(如加载状态提示),进一步提升表格的实用性和交互性。

图片来源于AI模型,如侵权请联系管理员。作者:酷小编,如若转载,请注明出处:https://www.kufanyun.com/ask/55838.html

(0)
上一篇2025年11月4日 16:28
下一篇 2025年11月4日 16:32

相关推荐

  • 服务器设备怎么开机

    服务器设备开机前的准备工作在正式开启服务器设备前,充分的准备工作是确保操作安全、避免硬件损坏的关键,需要检查服务器周围的环境,确保机房温度、湿度符合设备要求(通常温度建议在18℃-27℃,湿度在40%-60%),同时保持设备周围通风良好,无杂物遮挡散热孔,确认电源连接是否稳定,包括主电源、UPS不间断电源(如配……

    2025年12月4日
    0150
  • 安康游戏服务器租售,性价比高吗?值得选择吗?

    随着互联网的普及,网络游戏已经成为人们休闲娱乐的重要方式之一,而一款游戏的成功与否,很大程度上取决于其服务器性能,选择一个稳定、高效的游戏服务器对于游戏运营商来说至关重要,以下是关于安康游戏服务器租用的详细介绍,安康游戏服务器租用优势稳定性强安康游戏服务器采用高品质硬件设备,确保游戏运行过程中不出现卡顿、延迟等……

    2025年11月26日
    090
  • AngularJS数据源如何动态绑定与高效更新?

    AngularJS作为一款经典的前端JavaScript框架,其数据绑定和依赖注入机制为构建动态单页应用提供了强大支持,在AngularJS生态中,数据源作为应用与后端服务或前端数据存储交互的核心桥梁,直接影响应用的性能、可维护性和用户体验,本文将深入探讨AngularJS中数据源的多种实现方式、核心特性、最佳……

    2025年10月31日
    0130
  • 曲靖服务器如何实现高效稳定运行?性价比与维护策略探讨?

    如何高效利用与维护曲靖服务器概述曲靖服务器,作为我国云南省曲靖市的重要信息化基础设施,承担着为当地企业提供稳定、高效、安全的网络服务的重要角色,随着互联网技术的飞速发展,曲靖服务器在推动曲靖市信息化建设、促进数字经济等方面发挥着越来越重要的作用,曲靖服务器如何高效利用选择合适的服务器类型根据企业业务需求,选择适……

    2025年11月20日
    0130

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注