2017-07-06 84 views
0

我想顯示更多信息onclick,但我有不同的div顯示/隱藏。 所以。我這樣說: 的狀態是:在React中顯示更多信息

this.state = { 
     showMore: false, 
     showRewards: false, 
     fees: false, 
     showFees: false 
    }; 

其中的div:

     <div className='some'> 
          <h3 >Rewards <i className="icon-im-rewards"></i></h3> 
            <h5 className="showMoreDetails" onClick={() => this.show('rewards') }>{ showRewards ? '-' : '+' } { showRewards ? 'Show Less' : 'Show More' }</h5> 
          { showRewards && detail.rewards.reward.map((name, i) => 
            <p key={i}> { name }</p> 
          ) 
          } 
         </div> 

功能:

顯示(名字){ 設{相冊更多>>暫,showRewards,showFees} = this.state;

if (name === 'hightlights' && showMore === false) { 
    this.setState({ 
     showMore: true 
    }); 
} else { 
    this.setState({ 
     showMore: false 
    }); 
} 

if (name === 'rewards' && showRewards === false) { 
    this.setState({ 
     showRewards: true 
    }); 
} else { 
    this.setState({ 
     showRewards: false 
    }); 
} 

if (name === 'fees' && showFees === false) { 
    this.setState({ 
     showFees: true 
    }); 
} else { 
    this.setState({ 
     showFees: false 
    }); 
} 

這太長,醜陋,不能正確工作(我一次只能看到一個擴展的div)如何​​改善它?

回答

2

這是一個更好的和更清潔的方式:

function show (name) { 

    let { showMore, showRewards, showFees } = this.state; 
    showMore = name === 'hightlights' && showMore === false; 
    showRewards = name === 'rewards' && showRewards === false; 
    showFees = name === 'fees' && showFees === false; 

    this.setState({ 
    showFees, 
    showRewards, 
    showMore 
    }); 
+0

這是好多了,但我還是隻能在同一時間看到一個 –

0

這可能是更容易,如果你能告訴我們細節&獎勵的結構。我想你在這裏映射一個單一的元素,這就是爲什麼它打印單個元素。然而,嘗試改變這條線,

detail.rewards.reward.map((name, i) => <p key={i}> { name }</p>) 

替換下面的代碼:

detail.rewards.map((reward, i) => <p key={i}> { reward.name }</p>)