2016-05-12 78 views
0

在我的租金細節編輯頁面,有一個圖像上傳用戶更新他們的圖像或刪除以前上傳的圖像從previousFile()並可以進一步添加圖像。 onDrop()和showFiles()上的顯示了進一步添加的圖像。我已經定義了handleRemove()刪除圖像,但它們不能正常工作。所有圖像被刪除,而不是用戶想要刪除的特定圖像。這可能是什麼原因?所有圖像被刪除而不是刪除圖標被點擊的特定圖像reactjs

enter image description here

代碼被縮短

export default class RoomDetail extends Component{ 
    constructor(props){ 
     super(props); 
     this.state = { rooms:[], isEditing:false }; 
     this.pk = this.props.data.pk; 
    } 

    componentDidMount(newUser){ 
     $.ajax({ 
      url:'/api/rentals/'+this.props.data.pk+'/', 
      type:'put', 
      contentType: "application/json", 
      data:JSON.stringify(newUser), 
      success: (data) => { 
       console.log('data',data); 
       }, 
       error: (xhr, status, err) => { 
       console.error(xhr, status, err.toString()); 
       } 
      }); 
    } 

    componentWillMount(){ 
     this.loadRoomFromServer(); 
    } 

    loadRoomFromServer(){ 
     $.ajax({ 
      url:'/api/rentals/'+this.props.data.pk, 
      dataType:'json', 
      success: (data) => { 
       console.log('data',data); 
       this.setState({rooms: data}); 
       }, 
       error: (xhr, status, err) => { 
       console.error(xhr, status, err.toString()); 
       } 
      }); 
    } 

    handleRemove(id){ 
     const files = this.state.rooms.gallery.slice(); 
     this.setState({rooms:files.splice(id,1)}); 
    } 

    renderRoomDetailSection(){ 
     let url = this.pk; 
     let imageFile; 
     let firstImage; 
     if(this.state.rooms.gallery){ 
      firstImage = this.state.rooms.gallery[0].image; 
      console.log('firstImage', firstImage); 
      imageFile = _.map(this.state.rooms.gallery, (image) => { 
      return(
        <div className="col-md-3"> 
         <img src={image.image} key={image.id} className="img-fluid img-rounded" /> 
        </div> 
       ); 
      }); 
     } 
     if (this.state.isEditing){ 
      return(
        <EditRent 
         ownerName={this.state.rooms.ownerName} 
         email = {this.state.rooms.email} 
         phoneNumber = {this.state.rooms.phoneNumber} 
         image = {this.state.rooms.gallery} 
         onRemove = {this.handleRemove.bind(this)} 
         pk={this.props.data.pk} /> 
       ) 
     } 
       return(
         <div className="detailListing"> 
         here is the rent details 
         </div> 
       ) 
    } 

    renderUserAction(){ 
     if (this.state.isEditing){ 
      return(
        save and cancel button is here 
       ); 

     } 

     return(
       <div className = "buttons"> 
       edit button is here 
       </div> 
      ); 
     } 

    render() { 
     return (
      <div className = "newRoomDetail" > 
       { this.renderRoomDetailSection() } 
       { this.renderUserAction() } 
      </div> 
     ); 
    } 
    } 

var fieldValues = { 
    ownerName:'name', 
    email:'[email protected]', 
    phoneNumber:'9842333333' 
} 


class EditRent extends React.Component{ 
constructor(props,context) { 
     super(props,context); 
     this.state = { 
      step: 1 
     }; 
     this.pk = this.props.pk; 
    } 

    saveValues(field_value) { 
    return function() { 
     fieldValues = Object.assign({}, fieldValues, field_value) 
    }() 
    } 

    nextStep(step) { 
    var step = this.state.step; 
    var newStep = step+1; 
    this.setState({step:newStep}); 
    } 

    previousStep(step) { 
    var step = this.state.step; 
    var newStep = step-1 
    this.setState({ 
     step : newStep 
    }); 
    } 

    showStep() { 
    switch (this.state.step) { 
    case 1: 
     return <RenderPersonalInfo fieldValues={fieldValues} 
          ownerName={this.props.ownerName} 
          email={this.props.email} 
          phoneNumber={this.props.phoneNumber} 
          nextStep={this.nextStep.bind(this)} 
          previousStep={this.previousStep.bind(this)} 
          saveValues={this.saveValues.bind(this)} /> 
    case 2: 
     return <RenderPhotos fieldValues={fieldValues} 
          image={this.props.image} 
          nextStep={this.nextStep.bind(this)} 
          previousStep={this.previousStep.bind(this)} 
          imageRemove={this.props.onRemove} 
          pk={this.props.pk} /> 
    } 
} 

    render() { 

    return (
     <main className="container"> 
     <div className="row"> 
      <div className="col-sm-12"> 
      <span className="progress-step">Step {this.state.step}</span> 
      </div> 
     </div> 
     <div className="container"> 
      <div className="row"> 
      {this.showStep()} 
      </div> 
     </div> 
     </main> 
    ) 
    } 
}; 

let image = []; 
class RenderPhotos extends React.Component { 
    constructor(props, context) { 
     super(props, context); 
     this.state = { 
      files: [] 
     }; 
    } 

    handleClick(image){ 
     this.props.imageRemove(image); 
    } 

    onDrop(files) { 
     console.log('Received files: ', files); 
     this.setState({ 
      files: files 
     }); 

     image = new FormData(files); 
     $.each(files,function(i,file){ 
     image.append('image',file); 
     }); 

    } 

    previousFile(){ 
     return(
      <ul className="gallery"> 
      { 
      _.map(this.props.image, (image,idx) => { 
         return(
          <li className="col-md-3" key={idx}> 
          <span className="remove"><i onClick= onClick= {this.handleClick.bind(this,image)} className = "fa fa-times" aria-hidden="true"></i></span> 
          <img src={image.image} key={image.id} className="img-fluid img-rounded" /> 
          </li> 
         ) 
        }) 
      } 
      </ul> 
     ) 
    } 

    showFiles() { 
     const { files } = this.state; 
     if (!files.length) { 
      return null; 
     } 
     return (
      <div> 
       <h3>Dropped files: </h3> 
       <ul className="gallery"> 
        { 
         _.map(files, (file, idx) => { 
          return (
           <li className="col-md-3" key={idx}> 
            <img src={file.preview} width={200}/> 
            <div>{file.name}</div> 
           </li> 
          ) 
         }) 

        } 
       </ul> 
      </div> 
     ); 
    } 

    render() { 
     return (
      <div> 
       <div className="col-md-12"> 
       <form method="POST" encType="multipart/form-data"> 
       <input type="hidden" name="csrfmiddlewaretoken" value="{{ csrf_token }}"/> 
        <Dropzone onDrop={this.onDrop.bind(this)} 
          style={style} 
          activeStyle={activeStyle} 
          accept="image/*"> 
        Try dropping some files here, or click to select files to upload. 
       </Dropzone> 
       </form> 
       { this.previousFile() } 
       { this.showFiles() } 

       </div> 
       <div className="row continueBtn text-right"> 
        <button className="btn how-it-works pull-left" onClick={this.props.previousStep.bind(this)}><i className="fa fa-hand-o-left"></i></button> 
        <button className="btn how-it-works pull-right" onClick={this.nextStep.bind(this)}><i className="fa fa-floppy-o"></i></button> 
       </div> 
      </div> 

    ); 
    } 
} 

刪除的部分是在RenderPhotos部件

+0

首次在我生命中我沒有看到任何開發商評論或aswering在這裏:) – pri

回答

1

這裏的問題是,您嘗試通過將它們設置爲本地狀態來移除來自道具(previousFile)的圖像。如果您要從本地狀態渲染圖像,那麼這種方法可行,但您所做的是直接從道具渲染,這會導致React看不到任何更改。要使圖像移除工作,您需要將移除邏輯移至父組件,併爲子組件提供觸發刪除的功能。

class Parent extends Component { 
 
    constructor() { 
 
    this.state = { 
 
     files: [] 
 
    }; 
 
    } 
 

 
    handleRemove(id) { 
 
    const files = this.state.files.slice(); 
 
    this.seState({ 
 
     files: files.splice(id, 1) 
 
    }); 
 
    } 
 

 
    render() { 
 
     return <Files files={this.state.files} onRemove={this.handleRemove.bind(this)} />; 
 
    } 
 
} 
 

 
function handleClick(id, props) { 
 
    props.handleRemove(id); 
 
} 
 

 
function Files(props) { 
 
    return (
 
     <ul> 
 
     {props.files.map(
 
     (file, key) => <li key={key} onClick={handleClick.bind(this, key, props)}>{file.name}</li> 
 
     )} 
 
     </ul> 
 
    ); 
 
}

+0

所以在我的情況,我有更新的房間對象,對不對?因爲圖像和其他值被加載到房間對象。 – pri

+0

是的,這是正確的'this.state.rooms.gallery' – edvinerikson

+0

我已更新我的代碼。當我點擊刪除圖標,而不是刪除特定圖像時,它會刪除所有圖像。 – pri