欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

react通過組件拆分實現購物車界面詳解

 更新時間:2022年08月15日 10:27:52   作者:是張魚小丸子鴨  
這篇文章主要介紹了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組件拆分內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • React中使用Mobx的方法

    React中使用Mobx的方法

    Mobx是一個前端“狀態(tài)管理框架”,狀態(tài)管理就是將分布在各個組件、各個模塊中的狀態(tài)的變化,按照一定的規(guī)則,進行統(tǒng)一的管理,這篇文章主要介紹了React中如何使用Mobx,需要的朋友可以參考下
    2023-02-02
  • react父組件調用子組件的方式匯總

    react父組件調用子組件的方式匯總

    在react中常用props實現子組件數據到父組件的傳遞,但是父組件調用子組件的功能卻不常用,下面這篇文章主要給大家介紹了關于react父組件調用子組件的相關資料,需要的朋友可以參考下
    2022-08-08
  • 詳解如何優(yōu)雅地在React項目中使用Redux

    詳解如何優(yōu)雅地在React項目中使用Redux

    這篇文章主要介紹了詳解如何優(yōu)雅地在React項目中使用Redux,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-12-12
  • react項目使用redux初始化方式

    react項目使用redux初始化方式

    這篇文章主要介紹了react項目使用redux初始化方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • Iconfont不能上傳如何維護Icon

    Iconfont不能上傳如何維護Icon

    這篇文章主要為大家介紹了在Iconfont還是不能上傳,要如何維護你的Icon,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • 詳解關于React-Router4.0跳轉不置頂解決方案

    詳解關于React-Router4.0跳轉不置頂解決方案

    這篇文章主要介紹了詳解關于React-Router4.0跳轉不置頂解決案,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-05-05
  • React Native使用百度Echarts顯示圖表的示例代碼

    React Native使用百度Echarts顯示圖表的示例代碼

    本篇文章主要介紹了React Native使用百度Echarts顯示圖表的示例代碼,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • React Refs轉發(fā)實現流程詳解

    React Refs轉發(fā)實現流程詳解

    Refs是一個 獲取 DOM節(jié)點或React元素實例的工具,在React中Refs 提供了一種方式,允許用戶訪問DOM 節(jié)點或者在render方法中創(chuàng)建的React元素,這篇文章主要給大家介紹了關于React中refs的一些常見用法,需要的朋友可以參考下
    2022-12-12
  • 使用ReactJS實現tab頁切換、菜單欄切換、手風琴切換和進度條效果

    使用ReactJS實現tab頁切換、菜單欄切換、手風琴切換和進度條效果

    這篇文章主要介紹了使用ReactJS實現tab頁切換、菜單欄切換、手風琴切換和進度條效果的相關資料,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2016-10-10
  • React通過useContext特性實現組件數據傳遞

    React通過useContext特性實現組件數據傳遞

    本文主要介紹了React如何通過useContext特性實現組件數據傳遞,文中有相關的代碼示例供大家參考,對我們學習React有一定的幫助,需要的朋友可以參考下
    2023-06-06

最新評論