반응형
Vue3에서 다국어 적용하기!
우선 저는 다국어 지원 vue-i18n 없이Pinia를 통해 다국어를 적용했습니다.
pinia 설치는 아래 포스팅을 통해 적용해주시면 됩니다
https://bman-note.tistory.com/44
vue3 - pinia 간단 세팅 방법
이번 포스팅에서는 vue3에서 상태관리를 위한 pinia 세팅을 해보겠습니다. pinia, pinia-plugin-persist 설치 pinia : 상태관리 라이브러리 참고링크 : https://pinia.vuejs.kr/core-concepts/ pinia-plugin-persist : storage 저
bman-note.tistory.com
1. Json 파일 생성
//kr.json
{
"key1": "안녕하세요",
"key2": "감사합니다."
}
//en.json
{
"key1": "hello",
}
2. 스토어 생성
//resLocales.js
import { defineStore } from "pinia";
import kr from "@/assets/locales/kr"; //json 파일위치
import en from "@/assets/locales/en"; //json 파일위치
//언어정보 스토어
export const useLocales = defineStore("locales", {
state: () => ({
country: "kr",//국가정보
locales: {
kr: kr,
en: en,
},
}),
getters: {},
actions: {
//다국어 정보 가져오기
getLocale(key) {
return this.locales[this.country][key] !== undefined // 없을경우 한국어 리턴
? this.locales[this.country][key]
: this.locales["kr"][key]; //
},
//국가세팅
setCountry(country){
this.country = country;
}
},
persist: {
enabled: true,
},
});
3. 페이지에 적용하기
//sample.vue
<template>
<button @click="locales.setCountry('kr')">한국어</button>
<button @click="locales.setCountry('en')">영어</button>
<br />
번역값 : {{ locales.getLocale('key1') }}<br />
<br />
</template>
<script setup>
import { useLocales } from "@/assets/js/store/modules/resLocales"; //store 파일
const locales = useLocales();
</script>
이렇게 Vue3 에서 vue-i18n 미사용 다국어 처리를 해보았습니다.
도움이되셨길 바랍니다.
data:image/s3,"s3://crabby-images/0e397/0e39780e656fd552b02808633d0f64fbba4b20e4" alt=""
반응형
'개발 > VUE' 카테고리의 다른 글
Vue3 - 간단한 토스트 알림 적용 (0) | 2024.07.15 |
---|---|
Vue - 두번 클릭해야 화면 이동 할 경우(a태그) (0) | 2024.02.27 |
Vue - WebSocket connection failed(webpack) 해결방법 (1) | 2023.12.20 |
Vue - v-html 사용 시 발생하는 주석 관련 에러 해결 방법 (0) | 2023.12.01 |
Vue - pinia 간단 세팅 방법 (0) | 2023.11.22 |