react通过组件拆分实现购物车界面详解

目录
  • 页面组件拆分图
  • 功能点

页面组件拆分图

功能点

  • 实现全选反选
  • 数量的增加和减少
  • 选中删除,单独删除
  • 商品总价和商品总数量的变化

首先在根组件中把页面的布局以及功能先实现,然后再拆分组件,最后通过组件传值进行属性和方法的传递

代码展示

app.js组件

import axios from 'axios';
import React, { Component } from 'react';
import './App.css';
import Cartfoot from './Component/Cartfoot';
import CartList from './Component/CartList';
export default class App extends Component {
  constructor() {
    super()
    this.state = {
      list: [],
      checked:false
    }
    this.getCart()
  }
  getCart = async () => {
    let res = await axios.get('http://127.0.0.1:3002/getCart')
    console.log(res.data.data);
    let carts = res.data.data
    carts.map(item => {
     return item.checked = false
    })
    this.setState({
      list: carts
    })
  }
  // 全选
  qx=(e)=>{
    let {list}=this.state
    list.map(item=>item.checked=e.target.checked)
    this.setState({
      list:list,
      checked:e.target.checked
    })
  }
  // 反选
  fx=(index)=>{
    let {list}=this.state
    list[index].checked = !list[index].checked
    this.setState({
      list:list,
      checked:list.every(item=>item.checked)
    })
  }
  // 选中删除
  checkDel=()=>{
    let {list}=this.state
    let delAll=list.filter(item=>!item.checked)
    this.setState({
      list:[...delAll]
    })
  }
  // 数量加减操作
  handlerNum=(index,type="jia")=>{
    let {list}=this.state
    type==='jia'?list[index].num++ :list[index].num--
    this.setState({
      list:list
    })
  }
  // 计算操作
  count=()=>{
    let total=0
    let nums=0
    let {list}=this.state
    list.forEach(item=>{
      if(item.checked){
        total+=item.num*item.prize
        nums+=item.num
      }
    })
    return [total,nums]
  }
  // 删除按钮
  Del=(index)=>{
    let {list}=this.state
    list.splice(index,1)
    this.setState({
      list:list
    })
  }
  render() {
    let { list ,checked} = this.state
    return (
      <div className='App'>
        <table className='table'>
          <thead>
            <tr>
              <th><input type="checkbox" checked={checked} onChange={this.qx}/></th>
              <th>ID</th>
              <th>名字</th>
              <th>图片</th>
              <th>价格</th>
              <th>数量</th>
              <th>操作</th>
            </tr>
          </thead>
          <CartList list={list} fx={this.fx} qx={this.qx} handlerNum={this.handlerNum} Del={this.Del} checked={checked}></CartList>
          <Cartfoot count={this.count} checkDel={this.checkDel}></Cartfoot>
        </table>
      </div>
    )
  }
}

在app组件中,我们把所有的方法和请求到的数据接口写在这里,然后再通过props属性进行组件间的通信

CartList.js组件

import React from 'react'
import CartItem from './CartItem'
export default function CartList(props) {
  return (
    // <div>
        <tbody>
          {
              props.list.map((item, index) => {
                return (
                  <CartItem {...props} item={item} index={index} key={index}/>
                )
              })
            }
        </tbody>
    // </div>
  )
}

上面的{...props}是因为组件在传递属性时,如果传递的时候是一个对象属性,我们可以使用扩展运算符传递数据

Cartfoot.js组件

import React from 'react'
export default function Cartfoot(props) {
  return (
        <tfoot>
        <tr>
              <td colSpan={7}>
                商品总价格:<strong>{props.count()[0]}</strong>
                商品总数量:<strong>{props.count()[1]}</strong>
                <button onClick={props.checkDel}>选中删除</button>
              </td>
        </tr>
        </tfoot>
  )
}

CartItem.js组件

import React from 'react'
import CartColltract from './CartColltract'
export default function CartItem(props) {
    let {item,index}=props
  return (
    <tr>
                    <td><input type="checkbox" checked={item.checked} onChange={()=>props.fx(index)}/></td>
                    <td>{item._id}</td>
                    <td>{item.name}</td>
                    <td><img src={item.phopo} alt="" /></td>
                    <td>{item.prize}</td>
                    <td>
                    <CartColltract {...props} item={item} index={index}></CartColltract>
                     </td>
                    <td><button onClick={()=>props.Del(index)}>删除</button></td>
                  </tr>
  )
}

CartColltract.js组件

import React from 'react'
export default function CartColltract(props) {
    let {index,item}=props
  return (
    <div>
         <button className='danger' disabled={item.num === 1} onClick={()=>props.handlerNum(index,'jian')}>-</button>
                      <input type="text" value={item.num} readOnly />
                      <button onClick={()=>props.handlerNum(index,'jia')}>+</button>
    </div>
  )
}

像我们上面组件那样,组件之间层层嵌套,我们不仅可以使用普通父传子,子传父的组件通信方式进行组件传值,也可以使用context兄弟组件通信

到此这篇关于react通过组件拆分实现购物车界面详解的文章就介绍到这了,更多相关react组件拆分内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • React列表栏及购物车组件使用详解

    本文实例为大家分享了React列表栏及购物车组件的具体代码,供大家参考,具体内容如下 一.组件介绍 商家详细界面(StoreDetail组件): import React from 'react'; import axios from 'axios'; import GoBack from '../smallPage/GoBack'; import '../../Assets/css/storeDetail.css'; import MenuList from '../../Mock/MenuL

  • React中父组件如何获取子组件的值或方法

    目录 父组件获取子组件的值或方法 方法一 方法二 方法三 React函数式组件传值之子传父 具体案例 效果展示 父组件获取子组件的值或方法 先来说下从哪获取的启发,想要从父组件获取子组件的值或方法... 一次写代码的时候,用 Antd 中的 Modal 包裹了一个子组件,子组件中包含 input 输入框,想要在点击对话框上面确定按钮时(即Modal 自带的 onOk方法),拿到其中输入的值 下面用一个父组件(Father.js)和子组件(Hearder.js)来演示如何能拿到值和方法: 方法一

  • React 实现爷孙组件间相互通信

    目录 前言 爷孙组件间通信 前言 最近在学习React,给大家总结下跨组件通信中,爷孙组件之间怎么相互通信.简单明了上代码直接一把梭,不多解释. 爷孙组件间通信 案例如下: 代码: //跨组件通信 import React, { Component } from 'react' //创建context 给初始值 const UserMessage = React.createContext({ nickName: 'yyy', level: 1 }) export default class T

  • React高阶组件的使用浅析

    目录 高阶函数 高阶组件 react常见的高阶函数 高阶组件形式 在学习高阶组件前,首先我们了解一下高阶函数 高阶函数 把一个函数作为另一个函数的参数,那么这个函数就是高阶函数 高阶组件 一个组件的参数是组件,并且返回值是一个组件,我们称这类组件为高阶组件 react常见的高阶函数 withRouter() memo() react-redux中connect 高阶组件形式 React中的高阶组件主要有两种形式:属性代理和反向继承 属性代理:一个函数接收一个WrappedComponent组件作

  • React构建组件的几种方式及区别

    目录 一.组件是什么 二.如何构建 函数式创建 通过 React.createClass 方法创建 继承 React.Component 创建 三.区别 一.组件是什么 组件就是把图形.非图形的各种逻辑均抽象为一个统一的概念(组件)来实现开发的模式 在React中,一个类.一个函数都可以视为一个组件 组件所存在的优势: 降低整个系统的耦合度,在保持接口不变的情况下,我们可以替换不同的组件快速完成需求,例如输入框,可以替换为日历.时间.范围等组件作具体的实现 调试方便,由于整个系统是通过组件组合起

  • 解决react组件渲染两次的问题

    目录 react组件渲染两次 react总结之避免不必要的重复渲染 类组件PureComponent 使用插件seamless-immutable 使用插件pure-render-decorator react组件渲染两次 可能会有人问,问什么我的组件明明是就让渲染一次,但是实际上却渲染两次呢?其实我也遇到了这个问题,那么下面我提出一种解决这个问题的一种方法. 如果你使用了react-router低于4.x版本中的hashHistory,那么问题就来了,出现这种情况的原因是因为router中进行

  • React Hook 四种组件优化总结

    目录 前言 组件抽取 memo 优化组件 React.memo 语法 useCallback 优化组件 useCallback 作用 useMemo 优化 useMemo 语法 useCallback 和 useMemo 区别 前言 React Hook 已成为当前最流行的开发范式,React 16.8 以后基于 Hook 开发极大简化开发者效率,同时不正确的使用 React Hook也带来了很多的性能问题,本文梳理基于 React Hook 开发组件的过程中如何提高性能. 组件抽取 优化前 每

  • react通过组件拆分实现购物车界面详解

    目录 页面组件拆分图 功能点 页面组件拆分图 功能点 实现全选反选 数量的增加和减少 选中删除,单独删除 商品总价和商品总数量的变化 首先在根组件中把页面的布局以及功能先实现,然后再拆分组件,最后通过组件传值进行属性和方法的传递 代码展示 app.js组件 import axios from 'axios'; import React, { Component } from 'react'; import './App.css'; import Cartfoot from './Componen

  • React函数式组件的性能优化思路详解

    优化思路 主要优化的方向有2个: 减少重新 render 的次数.因为在 React 里最重(花时间最长)的一块就是 reconction(简单的可以理解为 diff),如果不 render,就不会 reconction. 减少计算的量.主要是减少重复计算,对于函数式组件来说,每次 render 都会重新从头开始执行函数调用. 在使用类组件的时候,使用的 React 优化 API 主要是:shouldComponentUpdate和 PureComponent 那么在函数式组件中,我们怎么做性能

  • React传值 组件传值 之间的关系详解

    react 组件相互之间的传值: 传值分父级组件传值给子组件 子组件传值给父组件 平级组件.没有嵌套的组件相互传值 1.父组件向子组件传值 父组件通过属性的形式来向子组件传值,子组件通过props来接受父组件传递过来的参数 //子组件 class list extends React.Component{ constructor(props){ super(props); // 初始化可以不用管 } render(){ return( <div> <div>{this.props.

  • React 高阶组件与Render Props优缺点详解

    目录 高阶组件 增强型高级组件 注入型高阶组件 高阶组件 VS Render Props 总结 高阶组件 高阶组件(HOC)是一个接受组件作为参数并返回一个新组件的函数,如果多个组件有相同的逻辑,将这些逻辑用函数封装,使它们能跨组件共用,这种用法称为高阶组件.下面的代码演示什么是高阶组件: export default function WithPrintLog(InnerComponent) { return class extends React.Component{ componentDi

  • react实现移动端二级路由嵌套详解

    页面效果展示 功能需求 根据下面不同的标题切换不同的页面,请求接口数据,渲染页面数据,点击左侧数据,进入详情页面,在右侧图片中点击返回返回左面页面 实现代码 我们用到了react中的router,首先我们要下载react的路由,命令是 react-router-dom@5 --save 路由5版本跟6版本使用语法上略有区别,现在使用较多的是5版本 我们首先在index.js文件中引入react路由,然后进行路由跳转 import { default as React } from 'react'

  • React状态管理Redux的使用介绍详解

    目录 1. 简介 2. 核心概念 3. redux工作流 4. 模拟redux工作流程 5. 使用redux 6. react-redux 1. 简介 Redux 是 JavaScript 应用的状态容器(对象),提供可预测的状态管理.可以让你开发出行为稳定可预测的应用,运行于不同的环境(客户端.服务器.原生应用),并且易于测试.Redux 除了和 React 一起用外,还支持其它界面库. 解决的问题:多层级组件间通信问题. 2. 核心概念 单一数据源 整个redux中的数据都是集中管理,存储于

  • React 模块联邦多模块项目实战详解

    目录 前提: 1. 修改webpack增加ModuleFederationPlugin 2.本地开发测试 3.根据路由变化自动加载对应的服务入口 4.线上部署 5.问题记录 前提: 老项目是一个多模块的前端项目,有一个框架层级的前端服务A,用来渲染界面的大概样子,其余各个功能模块前端定义自己的路由信息与组件.本地开发时,通过依赖框架服务A来启动项目,在线上部署时会有一个总前端的应用,在整合的时候,通过在获取路由信息时批量加载各个功能模块的路由信息,来达到服务整合的效果. // config.js

  • Electron整合React使用搭建开发环境的步骤详解

    简介 用于构建用户界面的 JavaScript 库 步骤 首先创建React npx create-react-app doc 进入到doc项目 cd doc 安装electron npm install electron --save-dev 安装依赖 判断是否为生产环境 cnpm install electron-is-dev --save-dev 在项目根目录创建main.js const { app ,BrowserWindow } = require('electron') const

  • React三大属性之Refs的使用详解

    refs是React中用来取得某个JSX组件或者某个DOM中的一些状态值的时候,用来获取节点的方法.在React官方的解释中,它的适用范围如下: 管理焦点,文本选择或媒体播放. 触发强制动画. 集成第三方 DOM 库. React文档中再三强调,请不要过度使用refs,所以当我们可以用dom原生对象解决时,尽量不要使用refs 依照之前的写法,首先是给出类组件和函数组件中refs的写法 类组件 在类中,refs有三种方式,目前最常用的是回调的形式使用,分别进行演示 //直接定义refs,已废弃

  • React三大属性之props的使用详解

    上期讲了state,接下来讲讲props.props功能在于组件间通信(父子组件),首先说说在各种组件中的用法: 类组件 //父组件传值 class Father extends React.PureComponent{ render(){ return ( <Son value={"son"} /> ) } } class Son extends React.PureComponent{ render(){ return ( <div>this data is

随机推荐