Skip to Content
Suspensive v3를 준비하고 있습니다. 🚀 더보기
문서보기@suspensive/reactwrap

wrap

wrap은 @suspensive/react에서 제공하는 Suspense, ErrorBoundary, ErrorBoundaryGroup 등으로 컴포넌트를 감싸기 위해 만들어졌습니다.

import { wrap, ErrorBoundaryGroup } from '@suspensive/react' import { useSuspenseQuery } from '@suspensive/react-query' export const Page = wrap .ErrorBoundaryGroup({ blockOutside: true }) .ErrorBoundary({ fallback: ({ error }) => <PageErrorFallback message={error.message} />, }) .Suspense({ fallback: <PageSkeleton /> }) .on( // <ErrorBoundaryGroup />, <ErrorBoundary />, <Suspense />에 감싸진 <Page/> 컴포넌트를 만듭니다. () => { const { data: postList } = useSuspenseQuery({ queryKey: ['posts'], queryFn: () => fetch(`https://example.com/posts`).then((res) => res.json()), }) return ( <> <ErrorBoundaryGroup.Consumer> {(group) => <button onClick={group.reset}>Reset all posts</button>} </ErrorBoundaryGroup.Consumer> {postList.map((post) => ( <PostItem id={post.id} /> ))} </> ) } ) const PostItem = wrap .ErrorBoundary({ fallback: ({ error }) => <>{error.message}</> }) .Suspense({ fallback: <PostSkeleton /> }).on < { id: string } > // <ErrorBoundary/>, <Suspense/>에 감싸진 <PostItem/> 컴포넌트를 만듭니다. ((props) => { const { data: post } = useSuspenseQuery({ queryKey: ['posts', props.id], queryFn: () => fetch(`https://example.com/posts/${props.id}`).then((res) => res.json() ), }) return <>{post.title}</> })
import { wrap, ErrorBoundaryGroup } from '@suspensive/react'
import { useSuspenseQuery } from '@suspensive/react-query'
import { useState, createElement } from 'react'

import { getPost, getPosts } from './api'

export const Example = wrap
  .ErrorBoundaryGroup({ blockOutside: true })
  .ErrorBoundary({ fallback: ({ error }) => <div>{error.message}</div> })
  .Suspense({ fallback: <div>Loading...</div> })
  .on(() => {
    const { data: postList } = useSuspenseQuery({
      queryKey: ['posts'],
      queryFn: getPosts,
    })

    return (
      <>
        <ErrorBoundaryGroup.Consumer>
          {(group) => <button onClick={group.reset}>Reset all posts</button>}
        </ErrorBoundaryGroup.Consumer>

        {postList.map((post) => (
          <PostItem key={post.id} id={post.id} />
        ))}
      </>
    )
  })

const PostItem = wrap
  .ErrorBoundary({
    fallback: ({ error }) => (
      <div
        style={{
          border: '1px solid black',
          padding: 10,
          margin: 10,
          color: 'red',
        }}
      >
        {error.message}
      </div>
    ),
  })
  .Suspense({ fallback: <div>Loading...</div> })
  .on<{ id: number }>((props) => {
    const { data: post } = useSuspenseQuery({
      queryKey: ['posts', props.id],
      queryFn: () => getPost(props.id),
    })
    const [throwError, setThrowError] = useState(false)

    return (
      <div style={{ border: '1px solid black', padding: 10, margin: 10 }}>
        <p>{post.title}</p>
        <button onClick={() => setThrowError(true)}>Throw error</button>
        {createElement(() => {
          if (throwError) {
            throw new Error('Error!')
          }

          return null
        })}
      </div>
    )
  })
수정된 날짜: