2017-07-06 2 views
0

Je veux montrer plus d'informations surclick, mais j'ai divs différents à afficher/masquer. Donc. Je le fais de cette façon: L'état est:Afficher plus d'informations dans React

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

Un des divs:

     <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> 

La fonction:

show (nom) { let {ShowMore , 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 
    }); 
} 

C'est trop long, laid et ne fonctionne pas correctement (je ne peux que voir un div élargi à la fois) Comment l'améliorer?

Répondre

2

Ceci est une meilleure et plus propre:

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

il est beaucoup mieux, mais je ne peux encore voir un à la fois –

0

Il pourrait être plus facile si vous pouviez nous montrer la structure des détails & récompenses. Je suppose que vous mappez un seul élément ici, c'est pourquoi il imprime un seul élément. Cependant, essayez de changer cette ligne,

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

avec le code ci-dessous remplacer:

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