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

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

Context API 不返回被點(diǎn)擊元素的 ID

Context API 不返回被點(diǎn)擊元素的 ID

慕雪6442864 2023-06-15 16:19:46
我正在構(gòu)建一個(gè) React 應(yīng)用程序,用戶可以在其中選擇他們想要的門票數(shù)量,然后從布局中選擇他們的座位。我正在使用適用于各種元素的上下文 API,但我正在嘗試返回用戶選擇的座位ID 。這是具有可點(diǎn)擊元素的組件,我需要從中獲取 ID -class ChooseSeats extends React.Component {    render(){        return(<Context.Consumer>            {(context) => {                return (                    <div>                        <p>Remaining tickets: {context.state.remainingSeats}</p>                        <p>Chosen seat: {context.state.chosenSeat}</p>                        <div>                        <div id="A1" onClick={context.chooseSeats}>                            <img src={freeSeat} alt="freeSeat"/>                        </div>                        <div id="A2" onClick={context.chooseSeats}>                            <img src={freeSeat} alt="freeSeat"/>                        </div>                        <div id="A3" onClick={context.chooseSeats}>                            <img src={freeSeat} alt="freeSeat"/>                        </div>                        </div>                    </div>                                  )}            }        </Context.Consumer>        )    }}這是上下文文件 -export class Provider extends React.Component {    state = {        chosenSeat: " ",        remainingSeats: 8    }    render() {        const { remainingSeats, chosenSeat } = this.state                return(            <Context.Provider value={{                state: this.state,                chooseSeats: (event) => {                    this.setState({                        chosenSeat: event.target.id,                        remainingSeats: remainingSeats - 1                    })                    console.log(chosenSeat)                },            }}>                {this.props.children}            </Context.Provider>        )    }}在我的實(shí)際應(yīng)用程序中,該remainingSeats值最初取自一些下拉菜單,用戶在這些菜單中選擇他們的票,但為了簡(jiǎn)單起見,在這種情況下我只給它一個(gè)默認(rèn)值 8。該choseSeats函數(shù)正在運(yùn)行,因?yàn)閞emainingSeats每次單擊一個(gè)座位時(shí)該值都會(huì)減少 1,但它不會(huì)返回 的 ID chosenSeat。我試過chosenSeat作為一個(gè)字符串和一個(gè)數(shù)組,但都沒有返回任何東西。誰(shuí)能告訴我哪里出錯(cuò)了?
查看完整描述

1 回答

?
慕的地8271018

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

這是因?yàn)閑vent.target.id是空的string。盡管您將 附加到onClick(div應(yīng)該是 abutton以使其可訪問),但如果您單擊子項(xiàng)img,則event.target是img。


您可以使用event.currentTarget- 它指的是事件處理程序已附加到的元素 ( div) - 或者您可以改為創(chuàng)建內(nèi)聯(lián)函數(shù)并傳遞 ID。


所以,而不是


<div id="A3" onClick={context.chooseSeats}><img ...

您可以使用


<button onClick={() => context.chooseSeats('A3')}><img ...

并更新您的chooseSeats,它現(xiàn)在收到一個(gè) ID,而不是event:


chooseSeats: (id) => {

  this.setState({

    chosenSeat: id,

    remainingSeats: remainingSeats - 1,

  })

  console.log(chosenSeat)

},


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

添加回答

舉報(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)