storybook配合vite + react生成组件文档

storybook配合vite + react生成组件文档

直接命令行初始化项目

javascript 复制代码
npm create vite com --template react-ts

并删除多余文件,并创建必要文件夹

建立一个简单的组件Button在package中

javascript 复制代码
interface propsTypes {
  label: string
}
const Button = (props: propsTypes) => {
  const {label} = props
  return(
    <button>{label}</button>
  )
}
export default Button

加入storybook各种配置

javascript 复制代码
npx storybook@latest init

可以直接通过storybook的命令生成适应项目的配置。并且会自动给你生成一个 .storybook的配置文件夹。其中含有入口文件main.ts和全局配置文件preview.ts

javascript 复制代码
// main.ts
import type { StorybookConfig } from "@storybook/react-vite";

const config: StorybookConfig = {
  // 指向的是组件文档的地址
  stories: ["../src/package/**/*.stories.@(js|jsx|mjs|ts|tsx)"],
  // 添加相对应的插件,具体根据组件库所需要的配置
  addons: [
    "@storybook/addon-links",
    "@storybook/addon-essentials",
    "@storybook/addon-onboarding",
    "@storybook/addon-interactions",
  ],
  // 直接指向storybook所要支持的框架
  framework: {
    name: "@storybook/react-vite",
    options: {},
  },
  // 自动文档的各种配置
  docs: {
    autodocs: "tag",
  },
};
export default config;
javascript 复制代码
// preview.ts
import type { Preview } from "@storybook/react";

const preview: Preview = {
  // 配置各种全局的样式
  parameters: {
    actions: { argTypesRegex: "^on[A-Z].*" },
    controls: {
      matchers: {
        color: /(background|color)$/i,
        date: /Date$/i,
      },
    },
    backgrounds: {
      default: 'gray',
      values: [
        {
          name: 'white',
          value: '#fff',
        },
        {
          name: 'gray',
          value: '#f0f0f0',
        },
        {
          name: 'twitter',
          value: '#00aced',
        },
        {
          name: 'facebook',
          value: '#3b5998',
        },
      ],
    },
  },
};

export default preview;

添加Button的文档

在package/Button下添加 index.stories.ts文件

javascript 复制代码
import type { Meta, StoryObj } from '@storybook/react';

import Button from "./index";
import './index.less'

const meta = {
  title: 'Example/Button',
  component: Button,
  // 这里也可以设置文档界面的各种配置
  parameters: {
   layout: 'centered',
  },
  tags: ['autodocs'],
} satisfies Meta<typeof Button>;

export default meta;

// 会直接生成文档组件的类型
type Story = StoryObj<typeof meta>;

export const Template: Story = {
  // 这里可以根据Button的propsType进行入参配置
  args: {
    label: 'DetailCard',
  },
};

最后执行启动命令就可以看到button的文档了

javascript 复制代码
 "storybook": "storybook dev -p 6006",
相关推荐
我只会写Bug啊5 小时前
Vue文件预览终极方案:PNG/EXCEL/PDF/DOCX/OFD等10+格式一键渲染,开源即用!
前端·vue.js·pdf·excel·预览
扯蛋4387 小时前
LangChain的学习之路( 一 )
前端·langchain·mcp
Mr.Jessy7 小时前
Web APIs学习第一天:获取 DOM 对象
开发语言·前端·javascript·学习·html
ConardLi8 小时前
Easy Dataset 已经突破 11.5K Star,这次又带来多项功能更新!
前端·javascript·后端
冴羽8 小时前
10 个被严重低估的 JS 特性,直接少写 500 行代码
前端·javascript·性能优化
rising start8 小时前
四、CSS选择器(续)和三大特性
前端·css
一 乐8 小时前
高校后勤报修系统|物业管理|基于SprinBoot+vue的高校后勤报修系统(源码+数据库+文档)
java·前端·javascript·数据库·vue.js·毕设
爱喝水的小周8 小时前
《UniApp 页面配置文件pages.json》
前端·uni-app·json
mapbar_front8 小时前
React中useContext的基本使用和原理解析
前端·react.js
贪婪的君子9 小时前
【每日一面】实现一个深拷贝函数
前端·js