Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 |
Tags
- 풀이
- C++
- 지갑
- 프로그래밍
- 백준
- 블록체인
- React
- three.js
- 니모닉
- baekjoon
- SASS
- 스토리북
- Storybook
- 기본수학1단계
- 코딩
- bip39
- scss
- 에러
- 리액트
- SVG
- 기본 수학 2단계
- frontend
- 우선순위 큐
- TypeScript
- Console
- 알고리즘
- Mnemonic
- Blockchain
- algorithm
- priority queue
Archives
- Today
- Total
Moong
[React+Typescript] Storybook에 Redux 설정하는 법 - could not found react-redux context value 에러 해결 본문
React
[React+Typescript] Storybook에 Redux 설정하는 법 - could not found react-redux context value 에러 해결
방울토망토 2023. 5. 3. 18:05storybook에 별도의 redux 설정 없이
redux를 사용하는 컴포넌트의 story를 렌더링하려고 하면 해당 에러를 마주치게 된다.
해결방법 - storybook에 redux 설정하는 법
💡 Provider로 감싸기
redux를 사용하는 프로젝트에서 index.tsx 파일에 Provider로 감싸주듯이
모든 story 파일들을 Provider로 감싸주면 된다.
.storybook 폴더에서
1. preview 파일의 확장자를 ts 에서 tsx로 변경 (⭐️중요⭐️ 이거 안하면 decorator가 안먹어요!)
2. decorators를 추가하여 Provider로 감쌉니다. (=> 모든 story에 설정되므로 global decorator라고도 합니다)
3. Provider에 프로젝트에서 사용하고있는 store 객체를 넣어줍니다.
import React from "react";
import type { Preview } from "@storybook/react";
import { Provider } from "react-redux";
import store from "../src/redux/store";
import 'reflect-metadata';
const preview: Preview = {
parameters: {
actions: { argTypesRegex: "^on[A-Z].*" },
controls: {
matchers: {
color: /(background|color)$/i,
date: /Date$/,
},
},
},
decorators: [
(Story) => (
/* provider 설정 */
<Provider store={store}>
<Story />
</Provider>
)
]
};
export default preview;
해결 완료! 🙌
'React' 카테고리의 다른 글
[React+Typescript] Storybook에 라우터(react-router-dom) 설정하기 (0) | 2023.05.04 |
---|---|
[React+Typescript] Storybook에 sass 설정하기(sass 에러 나는 경우) (0) | 2023.05.04 |
[React+Typescript] Storybook 에러 해결법 - element type is invalid (0) | 2023.05.03 |
[React+Typescript] Storybook 도입하기 (0) | 2023.05.03 |
[React] Notification custom hook 만들기 - 알림 아이콘, 알림음 설정 (0) | 2023.04.19 |
Comments