簡體   English   中英

將Props Callback與React Native一起使用

[英]Use Props Callback with react native

我想知道如何通過react native傳遞回調。

目前,我有3個組成部分:

MessageTypeText.js-> MessageButtons.js-> MessageButton.js

1個MessageButton.js

export default class MessageButton extends React.Component {

    clickButton(button) {
        console.log('message button');
        this.props.callBackFunction('PAYLOAD' , button.payload);
    }

    render() {
        let button = this.props.button;

        return (
            <TouchableOpacity onPress={() => this.clickButton(button)}>
                <Text>
                    { button.title }
                </Text>
            </TouchableOpacity>
        );
    }
}

2個MessageButtons.js

export default class MessageButtons extends React.Component {

    sendMessageToAPI(messageType, data) {
        console.log('message buttons');
        this.props.callBackMessageButtons(messageType , data);
    }

    renderButtons(buttons) {
        return(buttons.map((button, indexButton) => {
            return <MessageButton key={indexButton}
                                  button={button}
                                  callBackFunction={this.sendMessageToAPI} />
        }))
    }

    ...
}

3 MessageTypeText.js

export default class MessageTypeText extends React.Component {

    sendMessageToAPI(messageType, data) {
        console.log('message type text');
        //this.props.callBackFunction(messageType , data);
    }

    renderButtons(message) {
        if(...){
        return (<MessageButtons buttons={message.attachment.payload.buttons}
                                                callBackMessageButtons={this.sendMessageToAPI} />)
        }
    }

    ...
}

當我單擊組件MessageButton.js中的TouchableOpacity(更深入)時,在控制台中看到了:

信息按鈕,信息按鈕

但我看不到:

訊息類型文字

我有這個錯誤:

無法讀取未定義的屬性“ callBackMessageButtons”(MessageButtons.js(第10行)

我可以執行this.props.callBackMessageButtons(messageType,data); MessageButtons.js中

我在渲染器中使用了箭頭功能,但始終出現此錯誤。

不要忘記綁定回調。 或者只是使用箭頭功能:

sendMessageToAPI = (messageType, data) => {
    console.log('message buttons');
    this.props.callBackMessageButtons(messageType , data);
}

如您所料, this對於在回調中進行this工作是必要的。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM