Vue3で使える多言語プラグイン

Vue.js
この記事は約5分で読めます。
スポンサーリンク

Webサイトを多言語化するにあたり、ネット検索すると、Vue2での情報が多い。
今回は、Vue3で使える多言語化プラグインを探してみました。

スポンサーリンク

Vue I18n

Vue3に対応していて、GitHubのスター数が多い多言語化プラグインとして「Vue I18n」が見つかりました。
使い方が丁寧に書かれていて、使いやすそうな多言語化プラグインです。

ライセンスは、MITライセンスです。

スポンサーリンク

インストール

インストール環境

今回は、以下の環境に「Vue I18n」をインストールしました。

ソフトウェアバージョン
PHP8.2.6
Laravel10.13.5
Vue.js3.2.37

インストール手順

「Vue I18n」のインストール手順です。

npmコマンドを使うには、Node.jsのインストールが必要です。

npm install vue-i18n@9

Laravelのプロジェクトで「Vue I18n」を使えるようにします。
/resources/js/app.js を編集します。

import './bootstrap';
import { createApp } from 'vue';

const app = createApp({});

import { createI18n } from 'vue-i18n';
import ja from '/lang/ja/i18n_ja.json';
import en from '/lang/en/i18n_en.json';
const i18n = createI18n({
    locale: 'ja',   // ★言語を指定
    fallbackLocale: 'en',
    messages: {
        ja : ja,
        en : en
    }
});
app.use(i18n);

import ExampleComponent from './components/ExampleComponent.vue';
app.component('example-component', ExampleComponent);

app.mount('#app');

英語版サイトにする場合、「locale: 'en'」としてください。

各言語のファイルは、Laravelプロジェクト直下の以下のパスに配置しています。
 /lang/{言語}/i18n_{言語}.json

{
  "Hello": "ハロー",
  "World": "ワールド"
}
スポンサーリンク

多言語化

多言語化するには、以下のようなコードを書けばOKです。
/resources/js/components/ExampleComponent.vue を編集しています。

<template>
    <div class="m-5">
        <h1>{{$t("Hello")}}</h1>
        <h1>{{text}}</h1>
    </div>
</template>

<script>
    export default {
        mounted() {
            console.log('Component mounted.');
            this.text = this.$t('World');
        },
        data() {
            return {
                text: ''
            }
        },
    }
</script>

vueファイルのスクリプト(script)内で、I18nを使うには、「this.$t('world')」とすればOKです。

ExampleComponent.vue を View から呼び出します。

ExampleComponentを<div id="app"></div>で囲うことを忘れずに!

<!DOCTYPE html>
<html lang="ja">
    <head>
        <meta charset="utf-8">
        <meta name="viewport" content="width=device-width, initial-scale=1">

        <title>Vue I18n</title>

        <!-- Scripts -->
        @vite(['resources/sass/app.scss', 'resources/js/app.js'])
    </head>
    <body>
        <div id="app">
            <example-component></example-component>
        </div>
    </body>
</html>

ビルドします。

npm run build

サイトにアクセスした結果、日本語で表示されました!
app.jsの「locale」に指定した言語で表示されるようになりました。


用語を定義した各言語のJSONファイルを切り替えることで、Webサイトの多言語化ができました。Vue3で多言語化したい場合、「Vue I18n」を採用してみてはどうでしょうか。

タイトルとURLをコピーしました