首页
/ Storybook项目在React 19升级后的StoryFn类型使用指南

Storybook项目在React 19升级后的StoryFn类型使用指南

2025-04-29 06:30:00作者:龚格成

背景介绍

随着React 19的发布,许多开发者开始将项目升级到这个新版本。在Storybook项目中,特别是使用TypeScript时,开发者遇到了一个常见的类型错误问题。这个问题主要出现在定义装饰器(decorators)时,当尝试使用StoryFn类型来标注Story组件时,TypeScript会报错提示缺少参数。

问题现象

在Storybook 8.4及以上版本中,当项目升级到React 19后,传统的装饰器写法会出现类型错误。开发者通常会这样定义装饰器:

export const decorators = [
    (Story: StoryFn) => (
        <MyProvider>
            <Story />
        </MyProvider>
    ),
]

升级后,TypeScript会提示StoryFn需要两个参数(args和context),但实际使用时没有提供这些参数。错误信息表明Story不能作为JSX组件使用,因为它的类型需要至少2个参数。

解决方案

正确的做法是使用Storybook提供的Decorator类型来定义装饰器,而不是直接使用StoryFn类型。以下是推荐的写法:

import { Decorator } from '@storybook/react';

export const decorators: Decorator[] = [
  (Story) => (
    <div>
      {Story()}
    </div>
  ),
]

这种写法明确指定了装饰器数组的类型为Decorator[],而Story参数会自动获得正确的类型推断。

类型使用场景区分

理解StoryFnDecorator类型的不同使用场景很重要:

  1. StoryFn类型:应该仅用于直接定义故事组件时使用,例如:
export const MyStory: StoryFn = () => <MyComponent />;
  1. Decorator类型:应该用于定义装饰器函数,它已经内置了对Story参数类型的正确处理。

技术原理

这个问题的根源在于React 19对JSX处理方式的改变,以及Storybook类型定义的更新。StoryFn类型实际上是一个需要接收args和context两个参数的函数,而直接将其作为JSX组件使用会导致类型不匹配。

Storybook提供的Decorator类型则专门为装饰器场景设计,它知道如何处理Story参数,无需开发者手动指定参数。

最佳实践建议

  1. 始终为装饰器数组明确指定Decorator[]类型
  2. 在装饰器内部,使用函数调用形式Story()而不是JSX形式<Story />
  3. 保留StoryFn类型仅用于故事组件定义
  4. 升级Storybook到最新版本以获得最佳的类型支持

总结

React 19的升级带来了许多改进,但也需要开发者调整一些习惯写法。在Storybook项目中,正确处理装饰器类型是确保类型安全的关键。通过使用正确的Decorator类型而非StoryFn,可以避免类型错误,同时保持代码的清晰和可维护性。

登录后查看全文
热门项目推荐
相关项目推荐