@laguna1132

Как работает bind в React?

Добрый день. Учу Реакт, и в примере одного урока встретился такой код:

import React from 'react';

import MessagePreview from './MessagePreview.jsx';

import messages from '../messages.json';

import './InboxPage.less';

const InboxPage = React.createClass({
    contextTypes: {
        router: React.PropTypes.object.isRequired
    },

    getInitialState() {
        return {
            messages
        };
    },

    handlePreviewClick(messageId) {
        this.context.router.push(`/inbox/messages/${messageId}`);
    },

    render() {
        const { messages } = this.state;

        const { messageId: selectedMessageId } = this.props.params;

        return (
            <div className='InboxPage'>
                <div className='messages'>
                    {
                        messages.map(message =>
                            <MessagePreview
                                key={message.id}
                                selected={message.id === selectedMessageId}
                                onClick={this.handlePreviewClick.bind(null, message.id)}
                                title={message.subject}
                                senderName={message.senderName}
                            />
                        )
                    }
                </div>

                <div className='message-container'>
                    {this.props.children}
                </div>
            </div>
        );
    }
});

export default InboxPage;


В строчке onClick={this.handlePreviewClick.bind(null, message.id)} методу передается контекст null, но при этом метод внутри себя обращается к this. Как такое может быть?
  • Вопрос задан
  • 922 просмотра
Решения вопроса 1
@Interface
в случае createClass методы bind'ятся автоматом (в отличии от class ... extends React.Component {}): https://toddmotto.com/react-create-class-versus-co...
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы