有没有办法将一个组件传递给另一个react组件?我想创建一个模型react组件,并传入另一个react组件,以透光该内容。
编辑:这里是一个reactJS代码,说明了我正在尝试做什么。http://codepen.io/aallbrig/pen/bEhjo
HTML
<div id="my-component">
<p>Hi!</p>
</div>
反应
/**@jsx React.DOM*/
var BasicTransclusion = React.createClass({
render: function() {
// Below 'Added title' should be the child content of <p>Hi!</p>
return (
<div>
<p> Added title </p>
{this.props.children}
</div>
)
}
});
React.renderComponent(BasicTransclusion(), document.getElementById('my-component'));
实际上,您的问题是如何编写高阶组件(HOC)。使用HOC的主要目标是防止复制粘贴。你可以把你的HOC写成一个纯功能组件或一个类,这里有一个例子:
class Child extends Component {
render() {
return (
<div>
Child
</div>
);
}
}
如果你想把你的父组件写成一个基于类的组件:
class Parent extends Component {
render() {
return (
<div>
{this.props.children}
</div>
);
}
}
如果你想把你的父组件写成一个函数组件:
const Parent = props => {
return (
<div>
{props.children}
</div>
);
}
实际上,您的问题是如何编写高阶组件(HOC)。使用HOC的主要目标是防止复制粘贴。你可以把你的HOC写成一个纯功能组件或一个类,这里有一个例子:
class Child extends Component {
render() {
return (
<div>
Child
</div>
);
}
}
如果你想把你的父组件写成一个基于类的组件:
class Parent extends Component {
render() {
return (
<div>
{this.props.children}
</div>
);
}
}
如果你想把你的父组件写成一个函数组件:
const Parent = props => {
return (
<div>
{props.children}
</div>
);
}
我更喜欢使用React内置API:
import React, {cloneElement, Component} from "react";
import PropTypes from "prop-types";
export class Test extends Component {
render() {
const {children, wrapper} = this.props;
return (
cloneElement(wrapper, {
...wrapper.props,
children
})
);
}
}
Test.propTypes = {
wrapper: PropTypes.element,
// ... other props
};
Test.defaultProps = {
wrapper: <div/>,
// ... other props
};
然后你可以用你想要的东西替换包装器div:
<Test wrapper={<span className="LOL"/>}>
<div>child1</div>
<div>child2</div>
</Test>