gpt4 book ai didi

javascript - 如何使用 storybook.js 预览带有 React Portal 的组件

转载 作者:行者123 更新时间:2023-12-05 04:36:52 28 4
gpt4 key购买 nike

我使用 popper.js 实现了一个 Popper 组件,并使用 React 的 Portal 来渲染 popper 元素。

现在我想预览我的 popper 组件,但它无法在 storybook.js 上创建门户

这是我的方法。

.storybook/preview.js

import { ThemeProvider } from 'emotion-theming';
import { Global } from '@emotion/react';
import { theme, normalize } from 'custom-theme';

export const parameters = {
actions: { argTypesRegex: '^on[A-Z].*' },
controls: {
matchers: {
color: /(background|color)$/i,
date: /Date$/,
},
},
};

export const decorators = [
Story => (
<>
<ThemeProvider theme={theme}>
<Global styles={normalize} />
{Story()}
<div id="popper-root"></div>
</ThemeProvider>
</>
),
];

Portal.tsx

import { ReactNode, useMemo } from 'react';
import { createPortal } from 'react-dom';

interface IPortal {
children: ReactNode;
portalId: string;
}

const Portal = ({ children, portalId }: IPortal) => {
const portalElement = useMemo<HTMLElement | null>(
() => document.getElementById(portalId),
[portalId],
);

if (!portalElement) {
throw new Error(`Undefined Portal Id : ${portalId}`);
}

return createPortal(children, portalElement);
};

export default Portal;

捕获错误信息

Error Image

有什么方法可以在 Storybook 上使用 React Portal 显示组件吗?如果没有,除了在 React 项目上测试之外,还有其他方法可以预览吗?

最佳答案

我可以通过添加来解决这个问题 <div id="popper-root"></div>到我的 ComponentStory 模板。

但有一件事是如果我在门户打开的情况下呈现故事,它找不到 popper-root .

关于javascript - 如何使用 storybook.js 预览带有 React Portal 的组件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70768370/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com