React/React 다국어

react-i18next로 언어에 따른 LTR 및 RTL 구현하기

atomicdev 2024. 10. 21. 13:30
728x90

LTR 및 RTL 개념 설명

**LTR (Left-to-Right)**와 **RTL (Right-to-Left)**는 텍스트와 콘텐츠의 읽기 및 배치 방향을 나타내는 개념입니다.

  • LTR (Left-to-Right): 왼쪽에서 오른쪽으로 읽는 텍스트 방향을 의미합니다. 전 세계 대부분의 언어, 예를 들어 영어, 한국어, 프랑스어 등이 LTR 방식으로 텍스트를 읽습니다. 이 방향에서는 콘텐츠와 텍스트가 왼쪽에서 오른쪽으로 정렬되고, 페이지 레이아웃도 이 흐름에 맞춰 구성됩니다.
  • RTL (Right-to-Left): 오른쪽에서 왼쪽으로 읽는 텍스트 방향을 의미하며, 주로 아랍어, 히브리어 등에서 사용됩니다. 이 방식에서는 텍스트뿐만 아니라, 레이아웃 구성 요소들도 오른쪽에서 왼쪽으로 정렬되며, 이 언어들에 맞는 UI를 제공해야 합니다.

RTLLTR의 차이점을 이해하는 것은 다국어 지원 웹사이트나 애플리케이션을 개발할 때 매우 중요합니다. 특히 RTL 언어를 지원할 때는 텍스트 방향뿐만 아니라 UI 전반의 배치도 적절하게 반영되도록 설계해야 합니다.

React 애플리케이션에서 i18next 를 사용하여 LTR(왼쪽에서 오른쪽) 및 RTL(오른쪽에서 왼쪽) 언어를 처리하는 모습


i18next에서 LTR/RTL 구현하기

i18next 라이브러리는 다국어 지원 웹사이트를 쉽게 구현할 수 있도록 도와줍니다. 또한, 언어에 따라 LTR 또는 RTL 방향을 동적으로 적용할 수 있는 기능도 제공합니다. i18next.dir() 메서드를 사용하여 특정 언어가 RTL 또는 LTR인지 확인할 수 있으며, 그에 맞춰 레이아웃을 조정할 수 있습니다.

i18next.dir() 사용 방법

  • 현재 설정된 언어의 읽기 방향을 확인하려면 i18next.dir()을 호출하면 됩니다. 이 함수는 기본적으로 현재 설정된 언어의 읽기 방향을 반환합니다.
    i18next.dir(); // 현재 언어의 읽기 방향 반환 (예: 'ltr' 또는 'rtl')
  • 특정 언어의 읽기 방향을 확인하려면, 해당 언어 코드를 i18next.dir() 메서드에 인자로 넘겨주면 됩니다.
    i18next.dir('en-US'); // -> "ltr"
    i18next.dir('ar');    // -> "rtl"

 

 

i18next.dir()를 사용한 예시 코드

아래는 i18next.dir()을 사용하여 다국어 웹사이트에서 LTR 및 RTL 방향을 적용하는 방법을 보여주는 예시입니다.

import React, { useEffect } from 'react';
import { useTranslation } from 'react-i18next';
import i18next from 'i18next';

const App = () => {
  const { t, i18n } = useTranslation();

  useEffect(() => {
    // 언어 변경 시 페이지 전체의 텍스트 방향을 업데이트
    const direction = i18next.dir(i18n.language);
    document.documentElement.dir = direction;  // HTML 문서의 텍스트 방향 설정
  }, [i18n.language]);

  return (
    <div>
      <h1>{t('welcome')}</h1>
      <p>{t('description')}</p>
    </div>
  );
};

export default App;

설명:

  • i18next.dir(): 현재 언어의 읽기 방향(rtl 또는 ltr)을 반환합니다. 이를 이용해 document.documentElement.dir을 설정하여 페이지 전체의 텍스트 방향을 설정합니다.
  • document.documentElement.dir: HTML 문서의 최상위 html 요소에 dir 속성을 추가하여 텍스트 방향을 변경합니다. 예를 들어, dir="rtl"이면 모든 텍스트와 레이아웃이 오른쪽에서 왼쪽으로 배치됩니다.

HTML 문서에서 dir 속성 변경 예시:

  1. LTR 언어를 사용할 때:페이지는 왼쪽에서 오른쪽으로 텍스트가 표시됩니다.
    <html dir="ltr">
  2. RTL 언어를 사용할 때:페이지는 오른쪽에서 왼쪽으로 텍스트가 표시됩니다.
    <html dir="rtl">
     

 

 


i18next와 LTR/RTL 구현의 실제 적용

이제, LTR/RTL 개념과 i18next.dir()을 사용하여 다국어 웹사이트에서 언어에 맞는 레이아웃을 어떻게 적용할 수 있는지 알 수 있습니다. 새로운 언어가 추가될 때마다 번거롭게 레이아웃을 수정할 필요 없이, i18next.dir()을 사용하여 자동으로 언어에 맞는 방향이 설정되도록 하면 됩니다. 특히 RTL 언어를 지원하는 다국어 웹사이트에서는 이 기능을 활용하여 사용자가 자연스럽게 콘텐츠를 읽을 수 있도록 UX를 개선할 수 있습니다.

장점:

  • 자동 방향 설정: 각 언어의 읽기 방향에 따라 LTR 또는 RTL이 자동으로 적용되어 번거로운 수동 설정을 피할 수 있습니다.
  • 유연한 확장성: 새로운 언어가 추가될 때 i18next.dir()을 이용하면 추가적인 레이아웃 조정 없이도 방향이 자동으로 설정됩니다.

마무리

LTRRTL은 다국어 웹사이트 개발에서 중요한 개념이며, 특히 RTL 언어는 콘텐츠뿐만 아니라 UI 배치도 함께 고려해야 합니다. i18next.dir()은 이러한 언어별 텍스트 방향을 자동으로 처리하는 데 유용한 도구입니다. 위의 예시처럼 i18next.dir()을 활용하면 언어에 따라 적절한 텍스트 방향을 쉽게 설정할 수 있으며, 이는 사용자 경험을 개선하는 데 크게 기여할 수 있습니다.

 

 

728x90