首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >点符号是如何用反应钩子来反应元件的?

点符号是如何用反应钩子来反应元件的?
EN

Stack Overflow用户
提问于 2020-05-14 01:17:55
回答 1查看 1K关注 0票数 3

我见过一些库在React中使用点符号组件

例如:

代码语言:javascript
复制
<Menu>
   <Menu.Item>Item 1</Menu.Item>
   <Menu.Item>Item 2</Menu.Item>
</Menu>

这是在类组件中使用静态关键字。

代码语言:javascript
复制
const Item = () => ...code

class Menu extends Component {
  static Item = Item

  ...code

由于带有React的功能组件不是类组件,这种模式是否仍然可以与功能组件一起使用(例如访问原型或其他什么?)

还能这样做吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-05-14 01:30:22

这种模式被称为复合成分。要将模式与功能组件一起使用,只需添加子组件(Item)作为主组件(Menu)的属性即可。

你可以在肯特C.道兹的文章- React Hooks: Compound Components 中找到更多的信息。

代码语言:javascript
复制
const Item = ({ children }) => (<li>{children}</li>);

const Menu = ({ children }) => (<ul>{children}</ul>);

Menu.Item = Item;


ReactDOM.render(
  <Menu>
     <Menu.Item>Item 1</Menu.Item>
     <Menu.Item>Item 2</Menu.Item>
  </Menu>,
  root
);
代码语言:javascript
复制
<script crossorigin src="https://unpkg.com/react@16/umd/react.development.js"></script>
<script crossorigin src="https://unpkg.com/react-dom@16/umd/react-dom.development.js"></script>

<div id="root"></div>

票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61787588

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档