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

相关推荐

  • 百度智能云登录入口在哪里?忘记密码怎么找回?

    百度智能云-登录是用户访问和使用百度智能云各项服务的入口,其登录流程的设计不仅注重便捷性,更融合了多重安全机制,为用户打造安全、高效、智能的云服务体验,作为百度自主研发的云计算服务平台,百度智能云提供了从云计算、大数据、人工智能到物联网等全方位的技术解决方案,而登录环节则是连接用户与这些核心服务的桥梁,其重要性……

    2025年11月3日
    040
  • AngularJS如何监听路由变化?具体方法有哪些?

    AngularJS 作为一款经典的前端框架,其路由管理功能(通过 ngRoute 模块或 ui-router 模块)是实现单页应用(SPA)页面的核心,在开发过程中,监听路由变化的需求十分常见,在路由切换时加载页面数据、记录用户访问轨迹、执行权限校验、销毁不再需要的资源等,本文将详细介绍 AngularJS 中……

    2025年10月24日
    050
  • AngularJS无缝滚动如何实现?兼容性怎么处理?

    AngularJS实现无缝滚动的技术方案与实践在Web开发中,无缝滚动是一种常见的交互效果,广泛应用于新闻轮播、产品展示、公告通知等场景,AngularJS作为一款经典的前端框架,通过其数据绑定和指令机制,可以高效实现无缝滚动功能,本文将详细介绍基于AngularJS的无缝滚动实现原理、核心代码结构、优化技巧及……

    2025年10月31日
    030
  • 如何在Linux系统中配置Apache防火墙规则?

    在Linux系统中,Apache作为广泛使用的Web服务器,其安全性配置至关重要,而Linux防火墙作为系统安全的第一道防线,通过合理的规则设置可以有效保护Apache服务免受未授权访问和恶意攻击,本文将详细介绍Apache与Linux防火墙的协同配置方法,涵盖基础概念、规则设置、高级优化及常见问题处理,帮助用……

    2025年10月24日
    030

发表回复

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