2017-08-08 63 views
0

我已經設置了我的Redux以從網上商店(商品,尺寸,價格)捕獲用戶選擇並將其發送到另一個Cart組件。這是完美的工作,但我想捕獲該項目的圖像,並將其發送到Cart。在每個產品頁面中,您可以將商品添加到購物車中,其中還有一張圖像,我也希望通過用戶選擇發送圖像。這是產品網頁組件的例子:如何使用Redux將圖像傳輸到另一個組件?

import React, { Component } from 'react'; 
import { connect } from 'react-redux'; 
import { addCart } from '../../actions'; 

import SeltzShirt from './seltzshirt.jpg'; 
import Slideone from './slideSeltzOne'; 
import Slidetwo from './slideSeltzTwo'; 
import RightArrow from './rightarrow'; 
import LeftArrow from './leftarrow'; 

export class ProductPage3 extends Component { 

    constructor(props) { 
     super(props); 
     this.state = { 
      slideCount: 1, 
      value: 'medium', cartData: {} 
     } 

     this.nextSlide = this.nextSlide.bind(this); 
     this.previousSlide = this.previousSlide.bind(this); 
     this.handleClick = this.handleClick.bind(this); 
     this.change = this.change.bind(this); 
    } 

    handleClick() { 
     let cart = {price:25,item:this.description.innerHTML,size:this.state.value}; 
     this.props.onCartAdd(cart); 
     console.log(cart); 
     this.itemSelection(cart); 
    } 

    ... 

    componentDidMount() { 
     window.scrollTo(0, 0) 
    } 

    render() { 
     return (
      <div className= "ProductPage" id="ProductPage"> 
       <div id='slider'> 
        {this.state.slideCount === 1 ? <Slideone /> : null} 
        {this.state.slideCount === 2 ? <Slidetwo /> : null} 

        <RightArrow nextSlide={this.nextSlide} /> 
        <LeftArrow previousSlide={this.previousSlide} /> 

       </div> 
       <div id='InfoSquare'> 
        <div id='wrapper'> 
         <div id='item' ref={i=>this.description=i}>LOGO TEE</div> 
         <div id='description'>Black tee 100% cotton with red silkscreened logo on front and back.</div> 
         <select id="size2" onChange={this.change} value={this.state.value}> 
          <option value="medium">Medium</option> 
          <option value="large">Large</option> 
          <option value="x-large">X-large</option> 
         </select> 
         <button onClick={this.handleClick} className="addit">ADD TO CART</button> 
        </div> 

       </div> 
      </div> 
     ); 
    } 

    nextSlide() { 
     this.setState({ slideCount: this.state.slideCount + 1 }) 
    } 

    previousSlide() { 
     this.setState({ slideCount: this.state.slideCount - 1 }) 
    } 

} 

const mapDispatchToProps = (dispatch) => { 
    return { 
     onCartAdd: (cart) => { 
      dispatch(addCart(cart)); 
     }, 
    } 
} 

function mapStateToProps(state) { 
    return { 
     cart: state.cart 
    }; 
} 

export default connect(mapStateToProps,mapDispatchToProps)(ProductPage3); 

這是我Cart組件:

import React, { Component } from 'react'; 
import {addCart} from './Shop'; 
import { removeCart } from '../../actions'; 
import { connect } from 'react-redux'; 

export class Cart extends Component { 
    constructor(props) { 
     super(props); 
     this.state = {items: this.props.cart,cart: [],total: 0}; 
    } 

    ... 

    render() { 
     return(
      <div className= "Webcart" id="Webcart"> 
       <div id='WebcartWrapper'> 
        <ul id='webCartList'> 
         {this.state.items.map((item, index) => { 
          return <li className='cartItems' key={'cartItems_'+index}> 
           <h4>{item.item}</h4> 
           <p>Size: {item.size}</p> 
           <p>Price: {item.price}</p> 
           <button onClick={() => this.handleClick(item)}>Remove</button> 
          </li> 
         })} 
        </ul> 
        <div>Total: ${this.countTotal()}</div> 
       </div> 
      </div> 
     ); 
    } 
} 



const mapDispatchToProps = (dispatch) => { 
    return { 
     onCartAdd: (cart) => { 
      dispatch(addCart(cart)); 
     }, 
     onCartRemove: (item) => { 
      dispatch(removeCart(item)); 
     }, 
    } 
} 

function mapStateToProps(state) { 
    return { cart: state.cart }; 
} 

export default connect(mapStateToProps, mapDispatchToProps)(Cart); 

Cart我渲染項目選擇的數據爲每個對象添加到購物車。這也是我想要顯示物品圖像的地方。

因爲我有一個像滑塊設置,幻燈片的一個的一個例子是:

import React, { Component } from 'react'; 
import take1 from './DETAIL.png'; 

const SlideNocHOne= (props) => { 

    return <img src= {take1} id="slide"></img> 
} 

export default SlideNocHOne; 

比方說,我要上Cart這個DETAIL.png形象,我怎麼可能與用戶選擇其轉移使用Redux?

這是我的終極版組件:

import { createStore, applyMiddleware, compose } from 'redux'; 
import { persistStore, autoRehydrate } from 'redux-persist'; 
import reducer from './reducers'; 
import thunkMiddleware from 'redux-thunk'; 
import {createLogger} from 'redux-logger'; 


const store = createStore(
    reducer, 
    undefined, 
    compose(
    applyMiddleware(createLogger(), thunkMiddleware), 
    autoRehydrate() 
) 
); 

persistStore(store, {whitelist: ['cart']}); 

export default store; 

import {ADD_CART} from './actions'; 
import {REMOVE_CART} from './actions'; 
import { REHYDRATE } from 'redux-persist/constants'; 

export default Reducer; 

var initialState = { 
    cart:{}, 
    data: [], 
    url: "/api/comments", 
    pollInterval: 2000 
}; 

function Reducer(state = initialState, action){ 
    switch(action.type){ 
     case REHYDRATE: 
       if (action.payload && action.payload.cart) { 
        return { ...state, ...action.payload.cart }; 
       } 
      return state; 

      case ADD_CART: 
       return { 
        ...state, 
        cart: [...state.cart, action.payload] 
       } 

      case REMOVE_CART: 
       return { 
        ...state, 
        cart: state.cart.filter((item) => action.payload !== item) 
       } 



      default: 
       return state; 
    }; 
} 

export const ADD_CART = 'ADD_CART'; 
export const REMOVE_CART = 'REMOVE_CART'; 

export function addCart(item){ 
    return { 
     type: ADD_CART, 
     payload: item 
    } 
}; 

export function removeCart(item){ 
    return{ 
     type:REMOVE_CART, 
     payload: item 
    } 
}; 

我如何使用我的終極版安裝到用戶選擇的圖像傳送到Cart

+0

你好,如果你能提供一個codepen鏈接我會絕對幫助你 – Jeffin

回答

0

如果組件的路徑相對穩定,並且圖像的位置是單一的,則可以簡單地使用組件的displayName(在您的示例中爲Cart等)並返回相對路徑爲圖像目錄。

如果你有,你可以只保存在減速鍵/值收集什麼樣的圖像的每個組件應該有,如:

{ 
    CartComponent: ['DETAIL.png', 'DETAIL_2.png'] 
    ... 
} 

當撕心裂肺只使用映射功能,將爲您提供一個相對路徑,就是這樣。喜歡的東西(或者你可以繪製出該數組):

const relativeImagePath = getRelativeImageDirPathByCompName('CartComponent') + this.props.images.CartComponent[0]; 

使用require在像模板獲取圖像:

<img src={require(relativeImagePath)} alt="Something"/>

相關問題