React props.children 怎么绑定事件

Image组件

import React, { Component, PropTypes } from 'react';
import ContextMenu from './ContextMenu';


class Image extends Component {

    render() {
        return (
            <div>
                <ContextMenu>
                    <div className="uploader"></div>
                </ContextMenu>
            </div>
        );
    }

}


export default Image;

ContextMenu组件

import React, { Component, PropTypes } from 'react';


class ContextMenu extends Component {

    handleContextMenu(event) {
        event.preventDefault();
        console.log(event);
    }

    render() {
        return (
            <div>
                {
                    React.Children.map(this.props.children, (child) => {
                        return (
                            <child
                                onContextMenu={this.handleContextMenu}
                            />
                        )
                    })
                }
            </div>
        );
    }

}

export default ContextMenu;

渲染出来的是:

<div><child></child></div>

用这种方式实现走不通,并没有把child解析出来而是返回了标签,还有其他办法可以实现绑定props.children的事件么?

测试地址:http://codepen.io/sanonz/pen/LZNBrg/

阅读 10k
2 个回答

用这个React.cloneElement()

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题