javascript - React props.children 怎么绑定事件
伊谢尔伦
伊谢尔伦 2017-04-11 11:04:35
0
2
503

Image组件

import React, { Component, PropTypes } from 'react'; import ContextMenu from './ContextMenu'; class Image extends Component { render() { return ( 

); } } export default Image;

ContextMenu组件

import React, { Component, PropTypes } from 'react'; class ContextMenu extends Component { handleContextMenu(event) { event.preventDefault(); console.log(event); } render() { return ( 

{ React.Children.map(this.props.children, (child) => { return ( ) }) }

); } } export default ContextMenu;

渲染出来的是:

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

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

伊谢尔伦
伊谢尔伦

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

Antworte allen (2)
洪涛

1 是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()

      Neueste Downloads
      Mehr>
      Web-Effekte
      Quellcode der Website
      Website-Materialien
      Frontend-Vorlage
      Über uns Haftungsausschluss Sitemap
      Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!