当前位置:   article > 正文

【简单粗暴】如何使用 React 优化 AG 网格性能

【简单粗暴】如何使用 React 优化 AG 网格性能

AG Grid 是一个功能丰富的 JavaScript 库,主要用于在 Web 应用程序中构建强大的数据表。它被近 90% 的财富 500 强公司使用,在商业智能 (BI) 应用程序和金融科技应用程序中特别有用。

21df654486b645d43e8aafdb466babc2.png

React 是用于构建企业 Web 和移动应用程序的 JavaScript 库的市场领导者。它被大公司广泛采用,并拥有庞大的社区。

在本文中,我们将设置一个 React Web 应用程序,并使用 AG Grid 来构建一个高性能的数据表。本文中的所有代码都可在此 GitHub 链接中找到。

先决条件

  • Node.js 和 npm 已安装在您的系统上。

  • 了解 JavaScript 和 React。

设置新的 React 应用程序

  • 验证是否已安装 NodeJS 和 NPM。要检查的命令:和node -vnpm -vb0ec33d76b94eabad210793a1f2c75e2.png

  • 我们将使用“创建 react app”来启动一个新的 React 应用程序,让我们使用npm install -g create-react-app

  • 使用创建一个新的 React 应用程序npx create-react-app AGGridReact

  • 等待应用程序完全创建,然后使用转到新创建的应用程序的文件夹cd AGGridReact

  • 使用 启动应用程序。很快,您将能够使用 URL 在 localhost 端口 3000 上访问此 react 应用程序npm start

  • 现在我们准备对我们的 React 应用程序进行修改。你可以使用你选择的代码编辑器,我用过Visual Studio Code。

将 AG Grid 集成到我们的 React 应用程序中

AG Grid 有两种版本,社区版和企业版。我们将使用社区版本,不会产生任何许可费用。企业版在大型公司中是首选,因为它提供了一组附加功能。

  • 使用以下命令安装具有 React 支持的 AG Grid 社区版本npm install ag-grid-react

  • 让我们在项目的 src 文件夹下创建两个文件夹:components 和 services。

  • 让我们在 services 文件夹下创建一个服务。该服务将承担与后端通信并获取数据的工作。为简单起见,我们将不执行实际的 API 调用,而是提供一个包含所有示例数据的 JSON 文件。

  • 让我们从这里创建文件并向其添加内容。movie-data.json

  • 添加到 services 文件夹。我们的服务将有两种方法和一种导出的常量。很快,所有这些都将变得有意义。下面是此文件的参考代码。movie-service.js

JavaScript的

  1. 1
  2. import movies from './movie-data.json';
  3. 2
  4. 3
  5. const DEFAULT_PAGE_SIZE = 5;
  6. 4
  7. 5
  8. const countOfMovies = async() => {
  9. 6
  10. return movies.movies.length;
  11. 7
  12. };
  13. 8
  14. 9
  15. const fetchMovies = async() => {
  16. 10
  17. return movies.movies;
  18. 11
  19. };
  20. 12
  21. 13
  22. export { DEFAULT_PAGE_SIZE, countOfMovies, fetchMovies };

在这一点上,让我们创建我们的 React 组件,它将保存 AG Grid Table。在 src 目录下的 components 文件夹下添加文件。AGGridTable.js

让我们在组件中导入 React 和 AG Grid,并制定基本的组件导出

JavaScript的

  1. 1
  2. import React, { useState, useEffect } from 'react';
  3. 2
  4. import { AgGridReact } from 'ag-grid-react';
  5. 3
  6. import 'ag-grid-community/styles/ag-grid.css';
  7. 4
  8. import 'ag-grid-community/styles/ag-theme-quartz.css';
  9. 5
  10. export const AgGridTable = () => {}

我们将使用该组件来渲染我们的表,该组件需要两个主要内容:AGGridReact

  • 我们希望在表格中显示的列。

  • 我们希望在表中显示的行。

我们必须传递一个名为 our 的参数,以告诉它我们希望如何设置我们的列。如果您查看我们的文件中的电影数据,我们有列 、 和 。让我们将这些映射到我们的列定义参数。我们可以使用以下代码行来实现它。columnDefsAGGridReactmovie-data.jsonmovieIDmovieNamereleaseYear

JavaScript的

  1. 1
  2. const columnDefs = [
  3. 2
  4. { field: 'movieId', headerName: "Movie ID", minWidth: 100 },
  5. 3
  6. { field: 'movieName', headerName: "Movie Name", flex: 1 },
  7. 4
  8. { field: 'releaseYear', headerName: "Release Year", flex: 1 }
  9. 5
  10. ];

我们需要获取实际的电影数据,我们将利用我们的电影服务中的功能。此外,我们希望在页面加载时加载它。这可以通过传递一个空的依赖数组来实现 React 的钩子。fetchMoviesuseEffect

JavaScript的

  1. 1
  2. useEffect(() => {
  3. 2
  4. const fetchCount = async () => {
  5. 3
  6. const totalCount = await countOfMovies();
  7. 4
  8. setTotalRecords(totalCount);
  9. 5
  10. }
  11. 6
  12. fetchCount();
  13. 7
  14. }, []);
  15. 8
  16. 9
  17. useEffect(() => {
  18. 10
  19. fetchData();
  20. 11
  21. }, []);
  22. 12
  23. 13
  24. const fetchData = async () => {
  25. 14
  26. setIsLoading(true);
  27. 15
  28. try {
  29. 16
  30. const response = await fetchMovies();
  31. 17
  32. setMovieData(response);
  33. 18
  34. } catch (error) {
  35. 19
  36. console.error(error);
  37. 20
  38. } finally {
  39. 21
  40. setIsLoading(false);
  41. 22
  42. }
  43. 23
  44. };

让我们添加一些漂亮的加载指示符变量,以向我们的用户指示正在处理某些内容。

JavaScript的

  1. 1
  2. const [isLoading, setIsLoading] = useState(false);
  3. 把所有东西放在一起,我们得到我们的组件,如下所示。
  4. JavaScript的
  5. 1
  6. import React, { useState, useEffect } from 'react';
  7. 2
  8. import { AgGridReact } from 'ag-grid-react';
  9. 3
  10. import 'ag-grid-community/styles/ag-grid.css';
  11. 4
  12. import 'ag-grid-community/styles/ag-theme-quartz.css';
  13. 5
  14. 6
  15. import { countOfMovies, fetchMovies } from '../services/movie-service';
  16. 7
  17. 8
  18. export const AgGridTable = () => {
  19. 9
  20. const [movieData, setMovieData] = useState([]);
  21. 10
  22. const [totalRecords, setTotalRecords] = useState(0);
  23. 11
  24. const [isLoading, setIsLoading] = useState(false);
  25. 12
  26. 13
  27. const columnDefs = [
  28. 14
  29. { field: 'movieId', headerName: "Movie ID", minWidth: 100 },
  30. 15
  31. { field: 'movieName', headerName: "Movie Name", flex: 1 },
  32. 16
  33. { field: 'releaseYear', headerName: "Release Year", flex: 1 }
  34. 17
  35. ];
  36. 18
  37. 19
  38. useEffect(() => {
  39. 20
  40. const fetchCount = async () => {
  41. 21
  42. const totalCount = await countOfMovies();
  43. 22
  44. setTotalRecords(totalCount);
  45. 23
  46. }
  47. 24
  48. fetchCount();
  49. 25
  50. }, []);
  51. 26
  52. 27
  53. useEffect(() => {
  54. 28
  55. fetchData();
  56. 29
  57. }, []);
  58. 30
  59. 31
  60. const fetchData = async () => {
  61. 32
  62. setIsLoading(true);
  63. 33
  64. try {
  65. 34
  66. const response = await fetchMovies();
  67. 35
  68. setMovieData(response);
  69. 36
  70. } catch (error) {
  71. 37
  72. console.error(error);
  73. 38
  74. } finally {
  75. 39
  76. setIsLoading(false);
  77. 40
  78. }
  79. 41
  80. };
  81. 42
  82. 43
  83. return (
  84. 44
  85. <>
  86. 45
  87. {isLoading && <div>Loading...</div>}
  88. 46
  89. 47
  90. <div
  91. 48
  92. className="ag-theme-quartz"
  93. 49
  94. style={{ height: 300, minHeight: 300 }}
  95. 50
  96. >
  97. 51
  98. {
  99. 52
  100. totalRecords > 0 &&
  101. 53
  102. <AgGridReact
  103. 54
  104. rowData={movieData}
  105. 55
  106. columnDefs={columnDefs}
  107. 56
  108. />
  109. 57
  110. }
  111. 58
  112. 59
  113. </div>
  114. 60
  115. </>
  116. 61
  117. )
  118. 62
  119. }

让我们更新我们的app.js以包含我们新构建的组件,并执行清理以删除基本的创建 React 应用生成的代码。以下是 app.js 的更新代码:

JavaScript的

  1. 1
  2. import './App.css';
  3. 2
  4. import { AgGridTable } from './components/AgGridTable';
  5. 3
  6. 4
  7. function App() {
  8. 5
  9. return (
  10. 6
  11. <div className="App">
  12. 7
  13. <header className="App-header">
  14. 8
  15. <h1>Welcome logged in user.</h1>
  16. 9
  17. </header>
  18. 10
  19. <AgGridTable></AgGridTable>
  20. 11
  21. </div>
  22. 12
  23. );
  24. 13
  25. }
  26. 14
  27. 15
  28. export default App;
  29. 16

我们的表格现在应该加载到 UI 上了。

95c69145b33ea48c71b30915fde59eb0.png

通过分页提高性能

到目前为止,我们一直在一次性呈现表中的所有行。这种方法在现实世界中无法扩展。想象一下,我们有 10000 行而不是 100 行,我们的页面会非常慢,UI 性能会受到巨大打击。

我们可以通过对数据进行分页来轻松增强这一点。简单来说,分页意味着将我们的数据分解为一组 x 个项目,并一次显示一个设置项目。

添加分页的一些主要好处是:

  • 减小了 DOM 大小,从而优化了内存使用

  • 提高渲染速度

  • 增强的滚动性能

  • 更新速度更快

让我们向设置中添加其他参数以启用分页。AGGridReact

  • pagination = true告诉 AG Grid 我们想要分页

  • paginationPageSize告诉 AG Grid 最初在页面上显示的默认项目数是多少。

  • 我们将向参数传递一个数组。它将定义我们允许用户选择的不同页面大小。paginationPageSizeSelector

  • totalRows告诉 AG Grid 总共有多少条记录,这反过来又有助于计算我们表中的页数。

  • 为了获得上述所有参数的正确值,我们需要更新代码以获取总行数并定义页面大小选择器数组。

JavaScript的

  1. 1
  2. import React, { useState, useEffect, useMemo } from 'react';
  3. 2
  4. import { AgGridReact } from 'ag-grid-react';
  5. 3
  6. import 'ag-grid-community/styles/ag-grid.css';
  7. 4
  8. import 'ag-grid-community/styles/ag-theme-quartz.css';
  9. 5
  10. 6
  11. import { DEFAULT_PAGE_SIZE, countOfMovies, fetchMovies } from '../services/movie-service';
  12. 7
  13. 8
  14. export const AgGridTable = () => {
  15. 9
  16. const [movieData, setMovieData] = useState([]);
  17. 10
  18. const [totalRecords, setTotalRecords] = useState(0);
  19. 11
  20. const [isLoading, setIsLoading] = useState(false);
  21. 12
  22. 13
  23. const columnDefs = [
  24. 14
  25. { field: 'movieId', headerName: "Movie ID", minWidth: 100 },
  26. 15
  27. { field: 'movieName', headerName: "Movie Name", flex: 1 },
  28. 16
  29. { field: 'releaseYear', headerName: "Release Year", flex: 1 }
  30. 17
  31. ];
  32. 18
  33. 19
  34. useEffect(() => {
  35. 20
  36. const fetchCount = async () => {
  37. 21
  38. const totalCount = await countOfMovies();
  39. 22
  40. setTotalRecords(totalCount);
  41. 23
  42. }
  43. 24
  44. fetchCount();
  45. 25
  46. }, []);
  47. 26
  48. 27
  49. useEffect(() => {
  50. 28
  51. fetchData();
  52. 29
  53. }, []);
  54. 30
  55. 31
  56. const fetchData = async () => {
  57. 32
  58. setIsLoading(true);
  59. 33
  60. try {
  61. 34
  62. const response = await fetchMovies();
  63. 35
  64. setMovieData(response);
  65. 36
  66. } catch (error) {
  67. 37
  68. console.error(error);
  69. 38
  70. } finally {
  71. 39
  72. setIsLoading(false);
  73. 40
  74. }
  75. 41
  76. };
  77. 42
  78. 43
  79. const paginationPageSizeSelector = useMemo(() => {
  80. 44
  81. return [5, 10, 20];
  82. 45
  83. }, []);
  84. 46
  85. 47
  86. return (
  87. 48
  88. <>
  89. 49
  90. {isLoading && <div>Loading...</div>}
  91. 50
  92. 51
  93. <div
  94. 52
  95. className="ag-theme-quartz"
  96. 53
  97. style={{ height: 300, minHeight: 300 }}
  98. 54
  99. >
  100. 55
  101. {
  102. 56
  103. totalRecords > 0 &&
  104. 57
  105. <AgGridReact
  106. 58
  107. rowData={movieData}
  108. 59
  109. columnDefs={columnDefs}
  110. 60
  111. pagination={true}
  112. 61
  113. paginationPageSize={DEFAULT_PAGE_SIZE}
  114. 62
  115. paginationPageSizeSelector={paginationPageSizeSelector}
  116. 63
  117. totalRows={totalRecords}
  118. 64
  119. />
  120. 65
  121. }
  122. 66
  123. 67
  124. </div>
  125. 68
  126. </>
  127. 69
  128. )
  129. 70
  130. }

有了这段代码,我们将在其中内置了漂亮的分页,并具有默认的页面大小。

2697a76c5ea77b654d10a671ad0667d0.png

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/秋刀鱼在做梦/article/detail/957945
推荐阅读
相关标签
  

闽ICP备14008679号