javascript - React props.children 怎么绑定事件
伊谢尔伦
伊谢尔伦 2017-04-11 11:04:35
[JavaScript讨论组]

Image组件

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


class Image extends Component {

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

}


export default Image;

ContextMenu组件

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


class ContextMenu extends Component {

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

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

}

export default ContextMenu;

渲染出来的是:

<p><child></child></p>

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

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

伊谢尔伦
伊谢尔伦

小伙看你根骨奇佳,潜力无限,来学PHP伐。

全部回复(2)
PHP中文网

1 <child /> 是html标签。React 的 JSX 里约定分别使用首字母大、小写来区分本地组件的类和 HTML 标签 http://reactjs.cn/react/docs/jsx-in-depth.html

2 this.props.children 有可能是一个单独的组件,也可能是组件集合 http://reactjs.cn/react/tips/children-props-type.html

3 答案 http://codepen.io/anon/pen/KMzEKw?editors=0011

怪我咯

用这个React.cloneElement()

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号