Pet*_* K. 2 typescript create-react-app antd storybook
我想使用 Typescript 在我的 CRA 项目中使用基于 AntDesign 组件构建的组件来设置 Storybook。
CRA - v3 故事书 - v5.25 AntDesign - v3.23.2
我成功设置了 CRA + AntDesign,设置了 Storybook,我的 AntDesign 组件使用 AntD css 类在 Storybook 中渲染,但缺少样式
我试过
这些方法都不允许我用样式渲染 AntD 组件
// .stories/webpack.config.js
const path = require("path");
module.exports = {
module: {
rules: [
{
loader: "babel-loader",
exclude: /node_modules/,
test: /\.js$/,
options: {
presets: ["@babel/react"],
plugins: [["import", { libraryName: "antd", style: true }]]
}
},
{
test: /\.less$/,
loaders: [
"style-loader",
"css-loader",
{
loader: "less-loader",
options: {
modifyVars: { "@primary-color": "#d8df19" },
javascriptEnabled: true
}
}
],
include: path.resolve(__dirname, "../")
}
]
}
};
Run Code Online (Sandbox Code Playgroud)
// .stories/.babelrc
{
"plugins": [
[
"import",
{
"libraryName": "antd",
"style": "css"
}
]
]
}
Run Code Online (Sandbox Code Playgroud)
// 我的组件基于 AntDesign
import { Menu } from "antd";
import React, { FC } from "react";
import { RouteComponentProps, withRouter } from "react-router";
import { styled } from "styletron-react";
export const Sidebar: FC<RouteComponentProps> = ({ history }) => {
const SidebarLayout = styled(Menu, {
height: "100vh",
width: "100%"
});
return (
<SidebarLayout
onSelect={item => {
history.push(item.key);
}}
defaultSelectedKeys={["/"]}
selectedKeys={[history.location.pathname]}
mode="inline"
theme="dark"
>
<Menu.Item key="/">Table View</Menu.Item>
<Menu.Item key="/dashboard">Dashboard</Menu.Item>
</SidebarLayout>
);
};
export default withRouter(Sidebar);
Run Code Online (Sandbox Code Playgroud)
// 我的故事
import { storiesOf } from "@storybook/react";
import { Button } from "antd";
import React from "react";
import { MemoryRouter } from "react-router";
import Sidebar from ".";
storiesOf("Sidebar", module).add("Renders a regular menu", () => {
return (
<MemoryRouter initialEntries={["/"]}>
<Sidebar />
<Button type="primary">Button</Button>
</MemoryRouter>
);
});
Run Code Online (Sandbox Code Playgroud)
// 运行故事书显示: 运行故事书的结果
我希望在我的故事书中呈现基于 AntD 的组件,就像在我的 CRA 项目中一样: 运行基于 CRA 的项目的结果
这是我如何让它与Storybook v6一起使用
步骤 1:安装 Ant design 的预设。来源
npm i -D @storybook/preset-ant-design
第 2 步:在 .storybook/main.js 中添加上述预设的引用。另请注意 @storybook/preset-create-react-app 的选项是如何被覆盖的。
module.exports = {
"stories": [
"../src/**/*.stories.mdx",
"../src/**/*.stories.@(js|jsx|ts|tsx)"
],
"addons": [
"@storybook/addon-links",
"@storybook/addon-essentials",
"@storybook/preset-ant-design",
{
"name": "@storybook/preset-create-react-app",
"options": {
"craOverrides": {
"fileLoaderExcludes": ["less"]
}
}
}
],
}
Run Code Online (Sandbox Code Playgroud)
看起来 Storybook 6.0 会处理其余的事情,就我而言,除了这两件事之外不需要任何更改。
| 归档时间: |
|
| 查看次数: |
3604 次 |
| 最近记录: |