插槽是一种让组件变得更加灵活和可复用的技术。它允许我们在组件内部预留一些位置,然后在组件使用时填充这些位置,实现外部内容的嵌套。
在React中,实现插槽可以通过两种方式:props传递和children属性。
这是一种最简单的插槽实现方式,父组件通过props将内容传递给子组件。
示例:
import React from 'react';
function Card(props) {
return (
{props.header}
);
}
function App() {
return (
Title} />
);
}
children属性:React组件有一个特殊的children属性,它可以用于访问组件的嵌套内容。
示例:
import React from 'react';
function Card(props) {
return (
{props.children}
);
}
function App() {
return (
Card content here.
);
}
注意:若是传递多个元素,children则为数组类型
import React from 'react';
function Card(props) {
return (
{props.children[0]}
{props.children[1]}
//或者可以直接写props.children
{props.children}
);
}
function App() {
return (
Card content here.
Else content
);
}
React实现作用域插槽还是使用props传值,只不过是要传递一个回调函数用来接收参数。
示例:
import React from 'react';
function Card(props) {
return (
{props.setHeader("CardHeader")}
);
}
function App() {
return (
{text}
} />
);
}