[React] ๐ŸŽทLottie ์‚ฌ์šฉ๋ฒ•

TATAยท2023๋…„ 9์›” 26์ผ
0

React

๋ชฉ๋ก ๋ณด๊ธฐ
26/28

โ–ท Lottie

JSON ํ˜•์‹์œผ๋กœ ์• ๋‹ˆ๋ฉ”์ด์…˜์„ ์ €์žฅํ•˜์—ฌ ๋น„๊ต์  ํŒŒ์ผ ํฌ๊ธฐ๊ฐ€ ์ž‘์€ Lottie.
Lottie์—์„œ ์›ํ•˜๋Š” ํŒŒ์ผ์„ ๋‹ค์šด๋กœ๋“œ ๋ฐ›์•„ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋‹ค.
๋ฐ›์•„์˜จ Lottie ํŒŒ์ผ์„ ๋ฏธ๋ฆฌ ํ”Œ๋ ˆ์ดํ•ด ๋ณผ ์ˆ˜ ์žˆ๋Š” ๊ณณ

# ์„ค์น˜
npm install --save react-lottie-player

(Next.js๋ผ๋ฉด jsonํŒŒ์ผ์€ publicํด๋”์— ๋„ฃ๊ณ  ์‚ฌ์šฉ)

import Lottie from 'react-lottie-player';
import loadingJson from '../public/lottie/animation_loading.json';

function LoadingLottie() {
  return (
    <Lottie loop animationData={loadingJson} play />
  );
}

export default LoadingLottie;

Next.js๋ผ๋ฉด dynamic import๋กœ ๊ฐ€์ ธ์™€์„œ ์‚ฌ์šฉํ•ด์•ผ ํ•จ

import { CSSProperties } from 'react';
import dynamic from 'next/dynamic';
import loadingJson from '@/public/json/loading.json';

interface Props {
  customStyle?: CSSProperties;
}

function LoadingLottie({ customStyle }: Props) {
  const Lottie = dynamic(() => import('react-lottie-player'), { ssr: false });

  return (
    <Lottie style={customStyle} loop animationData={loadingJson} play />
  );
}

export default LoadingLottie;

๊ณตํ™ˆ์—์„œ json ํŒŒ์ผ์„ ๋‹ค์šด๋กœ๋“œ ๋ฐ›์•„ ์‚ฌ์šฉํ•  ์ˆ˜๋„ ์žˆ์ง€๋งŒ,
์ง์ ‘ ๋งŒ๋“  ์• ๋‹ˆ๋ฉ”์ด์…˜์„ Lottie๋กœ ์‚ฌ์šฉํ•˜๊ณ  ์‚ฌ์šฉํ•˜๊ณ  ์‹ถ๋‹ค๋ฉด
๐Ÿ‘‰ ์—ํŽ™์—์„œ ๋กœํ‹ฐ ์• ๋‹ˆ๋งค์ด์…˜ ๋งŒ๋“ค๊ธฐ1
๐Ÿ‘‰ ์—ํŽ™์—์„œ ๋กœํ‹ฐ ์• ๋‹ˆ๋งค์ด์…˜ ๋งŒ๋“ค๊ธฐ2

profile
๐ŸŒฟ https://www.tatahyeonv.com

0๊ฐœ์˜ ๋Œ“๊ธ€