ReactJS - 列表
列表和 For
React 中最常见的模式是将项目集合转换为 React 元素。JavaScript 有很多选项可以操作集合。让我们在本章中了解如何使用 for 循环使用集合。
for 循环
简单易用的解决方案是使用经过时间测试的 for 循环遍历集合并使用 JSX 表达式创建最终的 React 元素。让我们创建一个 React 应用并尝试应用 for 循环。
使用 create-react-app 创建一个新应用并启动该应用。
create-react-app myapp cd myapp npm start
接下来,在 components 文件夹下创建一个组件 ExpenseListUsingForLoop (src/components/ExpenseListUsingForLoop.js)
import React from 'react' class ExpenseListUsingForLoop extends React.Component { render() { return <table> <thead> <tr> <th>Item</th> <th>Amount</th> </tr> </thead> <tbody> </tbody> <tfoot> <tr> <th>Sum</th> <th></th> </tr> </tfoot> </table> } } export default ExpenseListUsingForLoop
在这里,我们创建了一个带有页眉和页脚的基本表格结构。
接下来,创建一个函数来查找总费用金额。我们稍后会在 render() 方法中使用它。
getTotalExpenses() { var items = this.props['expenses']; var total = 0; for(let i = 0; i < items.length; i++) { total += parseInt(items[i]); } return total; }
这里 getTotalExpenses 循环遍历费用 props,汇总总费用。然后在 render 方法中添加费用项目和总金额。
render() { var items = this.props['expenses']; var expenses = [] for(let i = 0; i < items.length; i++) { expenses.push(<tr><td>item {i + 1}</td><td>{items[i]}</td></tr>) } var total = this.getTotalExpenses(); return <table> <thead> <tr> <th>Item</th> <th>Amount</th> </tr> </thead> <tbody> {expenses} </tbody> <tfoot> <tr> <th>Sum</th> <th>{total}</th> </tr> </tfoot> </table> }
这里,
使用 for 循环导航费用数组中的每个项目,使用 JSX 生成表格行 (tr),最后将其推送到费用数组中。
我们在 JSX 表达式中使用了 expenses 数组来包含生成的行。
getTotalExpenses 方法查找总费用金额并将其添加到 render 方法中。
ExpenseListUsingForLoop 组件的完整源代码如下 −
import React from 'react' class ExpenseListUsingForLoop extends React.Component { getTotalExpenses() { var items = this.props['expenses']; var total = 0; for(let i = 0; i < items.length; i++) { total += parseInt(items[i]); } return total; } render() { var items = this.props['expenses']; var expenses = [] for(let i = 0; i < items.length; i++) { expenses.push(<tr><td>item {i + 1}</td><td>{items[i]}</td></tr>) } var total = this.getTotalExpenses(); return <table> <thead> <tr> <th>Item</th> <th>Amount</th> </tr> </thead> <tbody> {expenses} </tbody> <tfoot> <tr> <th>Sum</th> <th>{total}</th> </tr> </tfoot> </table> } } export default ExpenseListUsingForLoop
接下来,使用 ExpenseListUsingForLoop 组件更新 App 组件 (App.js)。
import ExpenseListUsingForLoop from './components/ExpenseListUsingForLoop'; import './App.css'; function App() { var expenses = [100, 200, 300] return ( <div> <ExpenseListUsingForLoop expenses={expenses} /> </div> ); } export default App;
接下来,在 App.css 中添加基本样式
/* Center tables for demo */ table { margin: 0 auto; } div { padding: 5px; } /* Default Table Style */ table { color: #333; background: white; border: 1px solid grey; font-size: 12pt; border-collapse: collapse; } table thead th, table tfoot th { color: #777; background: rgba(0,0,0,.1); text-align: left; } table caption { padding:.5em; } table th, table td { padding: .5em; border: 1px solid lightgrey; }
最后,在浏览器中检查应用程序。它将显示如下所示的费用 −

ECMASCript 6 for 循环
让我们更改应用程序并使用 ECMAScript 6 中引入的 for .. of 循环。
for(const [idx, item] of items.entries()) { expenses.push(<tr><td>item {idx + 1}</td><td>{item}</td></tr>) }
这里,
idx 表示数组的索引。
item 表示数组中每个位置上的支出项。
entries 方法解析数组并将其作为键值对数组返回。key 表示数组的索引,value 表示相应键中数组的值。
如果不需要索引,那么我们可以跳过 entries() 方法,如下所示 −
for(const item of items) { expenses.push(<tr><td></td><td>{item}</td></tr>) }