- ReactJS 教程
- ReactJS - 首页
- ReactJS - 简介
- ReactJS - 路线图
- ReactJS - 安装
- ReactJS - 特性
- ReactJS - 优点与缺点
- ReactJS - 架构
- ReactJS - 创建 React 应用
- ReactJS - JSX
- ReactJS - 组件
- ReactJS - 嵌套组件
- ReactJS - 使用新创建的组件
- ReactJS - 组件集合
- ReactJS - 样式
- ReactJS - 属性 (props)
- ReactJS - 使用属性创建组件
- ReactJS - props 验证
- ReactJS - 构造函数
- ReactJS - 组件生命周期
- ReactJS - 事件管理
- ReactJS - 创建一个事件感知组件
- ReactJS - 在支出管理器应用中引入事件
- ReactJS - 状态管理
- ReactJS - 状态管理 API
- ReactJS - 无状态组件
- ReactJS - 使用 React Hooks 进行状态管理
- ReactJS - 使用 React Hooks 的组件生命周期
- ReactJS - 布局组件
- ReactJS - 分页
- ReactJS - Material UI
- ReactJS - Http 客户端编程
- ReactJS - 表单编程
- ReactJS - 受控组件
- ReactJS - 非受控组件
- ReactJS - Formik
- ReactJS - 条件渲染
- ReactJS - 列表
- ReactJS - Keys
- ReactJS - 路由
- ReactJS - Redux
- ReactJS - 动画
- ReactJS - Bootstrap
- ReactJS - Map
- ReactJS - 表格
- ReactJS - 使用 Flux 管理状态
- ReactJS - 测试
- ReactJS - CLI 命令
- ReactJS - 构建和部署
- ReactJS - 示例
- Hooks
- ReactJS - Hooks 简介
- ReactJS - 使用 useState
- ReactJS - 使用 useEffect
- ReactJS - 使用 useContext
- ReactJS - 使用 useRef
- ReactJS - 使用 useReducer
- ReactJS - 使用 useCallback
- ReactJS - 使用 useMemo
- ReactJS - 自定义 Hooks
- ReactJS 高级
- ReactJS - 可访问性
- ReactJS - 代码分割
- ReactJS - Context
- ReactJS - 错误边界
- ReactJS - 转发 Refs
- ReactJS - Fragments
- ReactJS - 高阶组件
- ReactJS - 与其他库集成
- ReactJS - 优化性能
- ReactJS - Profiler API
- ReactJS - Portals
- ReactJS - 无 ES6 ECMAScript 的 React
- ReactJS - 无 JSX 的 React
- ReactJS - 调和
- ReactJS - Refs 和 DOM
- ReactJS - 渲染 Props
- ReactJS - 静态类型检查
- ReactJS - Strict Mode
- ReactJS - Web Components
- 其他概念
- ReactJS - 日期选择器
- ReactJS - Helmet
- ReactJS - 内联样式
- ReactJS - PropTypes
- ReactJS - BrowserRouter
- ReactJS - DOM
- ReactJS - 走马灯
- ReactJS - 图标
- ReactJS - 表单组件
- ReactJS - 参考 API
- ReactJS 有用资源
- ReactJS - 快速指南
- ReactJS - 有用资源
- ReactJS - 讨论
ReactJS - 列表支出
打开 ExpenseEntryItemList.js 并从 redux 库导入 connect。
import { connect } from 'react-redux';
接下来,导入 addExpenseList 和 deleteExpense actions。
import { getExpenseList, deleteExpense } from '../actions/expenseActions';
接下来,使用 props 添加构造函数。
constructor(props) { super(props); }
接下来,在 componentDidMount() 生命周期中调用 getExpenseList。
componentDidMount() { this.props.getExpenseList(); }
接下来,编写一个方法来处理删除支出选项。
handleDelete = (id,e) => { e.preventDefault(); this.props.deleteExpense(id); }
现在,让我们编写一个函数 getTotal 来计算总支出。
getTotal() { let total = 0; if (this.props.expenses != null) { for (var i = 0; i < this.props.expenses.length; i++) { total += this.props.expenses[i].amount } } return total; }
接下来,更新 render 方法并列出支出项目。
render() { let lists = []; if (this.props.expenses != null) { lists = this.props.expenses.map((item) => <tr key={item.id}> <td>{item.name}</td> <td>{item.amount}</td> <td>{new Date(item.spendDate).toDateString()}</td> <td>{item.category}</td> <td><a href="#" onClick={(e) => this.handleDelete(item.id, e)}>Remove</a></td> </tr> ); } return ( <div> <table> <thead> <tr> <th>Item</th> <th>Amount</th> <th>Date</th> <th>Category</th> <th>Remove</th> </tr> </thead> <tbody> {lists} <tr> <td colSpan="1" style={{ textAlign: "right" }}>Total Amount</td> <td colSpan="4" style={{ textAlign: "left" }}> {this.getTotal()} </td> </tr> </tbody> </table> </div> ); }
接下来,编写 mapStateToProps 和 mapDispatchToProps 方法。
const mapStateToProps = state => { return { expenses: state.data }; }; const mapDispatchToProps = { getExpenseList, deleteExpense };
在这里,我们将 redux store 中的支出项目映射到 expenses 属性,并将调度器 getExpenseList 和 deleteExpense 附加到组件属性。
最后,使用 connect api 将组件连接到 Redux store。
export default connect( mapStateToProps, mapDispatchToProps )(ExpenseEntryItemList);
完整的应用程序源代码如下所示:
import React from "react"; import { connect } from 'react-redux'; import { getExpenseList, deleteExpense } from '../actions/expenseActions'; class ExpenseEntryItemList extends React.Component { constructor(props) { super(props); } componentDidMount() { this.props.getExpenseList(); } handleDelete = (id, e) => { e.preventDefault(); this.props.deleteExpense(id); } getTotal() { let total = 0; if (this.props.expenses != null) { for (var i = 0; i < this.props.expenses.length; i++) { total += this.props.expenses[i].amount } } return total; } render() { let lists = []; if (this.props.expenses != null) { lists = this.props.expenses.map((item) => <tr key={item.id}> <td>{item.name}</td> <td>{item.amount}</td> <td>{new Date(item.spendDate).toDateString()}</td> <td>{item.category}</td> <td><a href="#" onClick={(e) => this.handleDelete(item.id, e)}>Remove</a> </td> </tr> ); } return ( <div> <table> <thead> <tr> <th>Item</th> <th>Amount</th> <th>Date</th> <th>Category</th> <th>Remove</th> </tr> </thead> <tbody> {lists} <tr> <td colSpan="1" style={{ textAlign: "right" }}>Total Amount</td> <td colSpan="4" style={{ textAlign: "left" }}> {this.getTotal()} </td> </tr> </tbody> </table> </div> ); } } const mapStateToProps = state => { return { expenses: state.data }; }; const mapDispatchToProps = { getExpenseList, deleteExpense }; export default connect( mapStateToProps, mapDispatchToProps )(ExpenseEntryItemList);
接下来,使用 npm 命令启动应用程序。
npm start
接下来,打开浏览器并在地址栏中输入 https://127.0.0.1:3000 并按回车键。
reactjs_example.htm
广告