亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Context API 不返回被點擊元素的 ID

Context API 不返回被點擊元素的 ID

慕雪6442864 2023-06-15 16:19:46
我正在構建一個 React 應用程序,用戶可以在其中選擇他們想要的門票數量,然后從布局中選擇他們的座位。我正在使用適用于各種元素的上下文 API,但我正在嘗試返回用戶選擇的座位ID 。這是具有可點擊元素的組件,我需要從中獲取 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>        )    }}在我的實際應用程序中,該remainingSeats值最初取自一些下拉菜單,用戶在這些菜單中選擇他們的票,但為了簡單起見,在這種情況下我只給它一個默認值 8。該choseSeats函數正在運行,因為remainingSeats每次單擊一個座位時該值都會減少 1,但它不會返回 的 ID chosenSeat。我試過chosenSeat作為一個字符串和一個數組,但都沒有返回任何東西。誰能告訴我哪里出錯了?
查看完整描述

1 回答

?
慕的地8271018

TA貢獻1796條經驗 獲得超4個贊

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


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


所以,而不是


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

您可以使用


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

并更新您的chooseSeats,它現在收到一個 ID,而不是event:


chooseSeats: (id) => {

  this.setState({

    chosenSeat: id,

    remainingSeats: remainingSeats - 1,

  })

  console.log(chosenSeat)

},


查看完整回答
反對 回復 2023-06-15
  • 1 回答
  • 0 關注
  • 156 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號