第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

通過(guò)父組件的 onClick 更新組件狀態(tài)

通過(guò)父組件的 onClick 更新組件狀態(tài)

瀟瀟雨雨 2023-03-18 16:56:58
我在應(yīng)用程序中的目標(biāo)是,當(dāng)單擊按鈕時(shí),將操作設(shè)置為新的并提供給子組件。一旦子組件收到這個(gè)值,它就應(yīng)該顯示來(lái)自 div 的文本。在進(jìn)一步的實(shí)施中,我將添加另一個(gè)按鈕,單擊此按鈕時(shí),它將設(shè)置要編輯的操作。子組件應(yīng)該自動(dòng)接收值并基于此返回另一個(gè) div。let actionToPerform = "";    function actionState(action){       if(action === 'new'){           actionToPerform = 'new'       }else{           actionToPerform = 'edit'       }    } <button onClick={() => actionState('new')}>Create new Shoppinglist</button> <button onClick={() => actionState('edit')}>Edit Shoppinglist</button> <Edit action={actionToPerform}/>子組件:export default class Edit extends React.Component {    constructor(props){        super(props);        this.state = {actionToPerform: this.props.action}    }        showTitle() {        if(this.state.actionToPerform === 'new'){            return <div>new Shoppinglist</div>        }else if(this.state.actionToPerform === 'edit'){            return <div>edit</div>        }else{            return <div>nothing to show</div>        }    }   render() {       return (           this.showTitle()       )   }}我知道我應(yīng)該以某種方式使用 componentDidMount 和 componentUpdate 來(lái)實(shí)現(xiàn)這一點(diǎn),但我無(wú)法做到。現(xiàn)在,在加載頁(yè)面時(shí),它會(huì)觸發(fā) onClick 操作,我不知道為什么。當(dāng)我點(diǎn)擊按鈕時(shí),沒(méi)有其他事情發(fā)生
查看完整描述

2 回答

?
拉莫斯之舞

TA貢獻(xiàn)1820條經(jīng)驗(yàn) 獲得超10個(gè)贊

父組件:


當(dāng)您更新組件時(shí),actionToPerform您的組件不知道并且不會(huì)重新呈現(xiàn),您需要將其保存在其state:


state = {

  actionToPerform: ""

}


updateState(actionToPerform){

    this.setState({ actionToPerform })

}


<button onClick={() => this.updateState('new')}>Create new Shoppinglist</button>

<button onClick={() => this.updateState('edit')}>Edit Shoppinglist</button>

<Edit action={actionToPerform}/>

現(xiàn)在,當(dāng)您單擊其中一個(gè)按鈕時(shí),狀態(tài)的值會(huì)更新并且組件會(huì)重新呈現(xiàn),將新值傳遞給子組件。


子組件:


您不應(yīng)該從 設(shè)置狀態(tài)的初始值props,請(qǐng)參閱反模式:無(wú)條件地將道具復(fù)制到狀態(tài)


您甚至可以將它們?nèi)縿h除,因?yàn)槟梢愿鶕?jù)props值進(jìn)行條件渲染:


export default class Edit extends React.Component {

  render() {

    return this.props.actionToPerform === "new" ? (

      <div>new Shoppinglist</div>

    ) : this.props.actionToPerform === "edit" ? (

      <div>edit</div>

    ) : (

      <div>nothing to show</div>

    );

  }

}


查看完整回答
反對(duì) 回復(fù) 2023-03-18
?
慕勒3428872

TA貢獻(xiàn)1848條經(jīng)驗(yàn) 獲得超6個(gè)贊

您應(yīng)該使用組件中的狀態(tài),而不是在組件Edit中使用狀態(tài)parentt,并將該狀態(tài)作為 prop 傳遞給子(編輯)組件并使用它。


父類.js


actionState = (action) => {

   if(action === 'new'){

      this.setState({ actionToPerform: 'new' })

   } else{

      this.setState({ actionToPerform: 'edit' })

   }

}

render() {

 return (

   <div>

     <button onClick={() => this.actionState('new')}>Create new Shoppinglist</button>

     <button onClick={() => this.actionState('edit')}>Edit Shoppinglist</button>

     <Edit action={this.state.actionToPerform}/>

   </div>

 )

}

孩子.js


export default class Edit extends React.Component {


    showTitle() {

        if(this.props.actionToPerform === 'new'){

            return <div>new Shoppinglist</div>

        } else if(this.props.actionToPerform === 'edit'){

            return <div>edit</div>

        } else{

            return <div>nothing to show</div>

        }

    }


   render() {

       return (

           this.showTitle()

       )

   }


查看完整回答
反對(duì) 回復(fù) 2023-03-18
  • 2 回答
  • 0 關(guān)注
  • 112 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)