# vue-i18n-loader

If you'd like to enable vue-i18n-loader, simply set vueI18nLoader option to true.

// nuxt.config.js

['nuxt-i18n', {
  vueI18nLoader: true
}]

You can now define translations using custom blocks in your Vue files:

<i18n>
{
  "en": {
    "hello": "hello world!"
  },
  "ja": {
    "hello": "こんにちは、世界!"
  }
}
</i18n>

<template>
  <p>{{ $t('hello') }}</p>
</template>

# YAML

<i18n>
en:
  hello: "hello world!"
ja:
  hello: "こんにちは、世界!"
</i18n>

<template>
 <p>{{ $t('hello') }}</p>
</template>

The following is needed in nuxt config file for YAML i18n blocks to work:

build: {
  extend(config) {
    config.module.rules.push({
      resourceQuery: /blockType=i18n/,
      type: "javascript/auto",
      loader: ["@kazupon/vue-i18n-loader", "yaml-loader"],
    });
  },
}