Home >Web Front-end >Vue.js >How to use Vue and Element-UI for international multi-language processing

How to use Vue and Element-UI for international multi-language processing

王林
王林Original
2023-07-21 09:33:061539browse

How to use Vue and Element-UI for international multi-language processing

Introduction:
In an era of increasing globalization, in order to enable websites and applications to adapt to users in different countries and regions , internationalized multilingual processing is becoming more and more important. Vue is a popular front-end development framework, and Element-UI is a set of UI libraries based on Vue. This article will introduce how to use Vue and Element-UI for international multi-language processing.

1. Install and introduce necessary dependent libraries
First, we need to install and introduce some necessary dependent libraries. In the root directory of the Vue project, open a terminal and run the following command:

npm install vue-i18n
npm install vant

Then, in the project's entry file (usually main.js), introduce and use these dependent libraries:

import Vue from 'vue'
import VueI18n from 'vue-i18n'
import vant from 'vant'
import 'vant/lib/index.css'

Vue.use(VueI18n)
Vue.use(vant)

// 初始化i18n实例
const i18n = new VueI18n({
  locale: 'zh-CN',  // 默认语言
  fallbackLocale: 'en',  // 如果当前语言包中没有对应的翻译文本,就会使用fallbackLocale中定义的语言包
  messages: {
    'zh-CN': require('./lang/zh-CN.json'),  // 引入中文语言包
    'en': require('./lang/en.json')  // 引入英文语言包
  }
})

// 将i18n实例绑定到Vue实例上
new Vue({
  el: '#app',
  i18n,
  render: h => h(App)
})

2. Create language pack files
Create a lang folder in the root directory of the project, and create multiple language pack files in the folder. For example, we create a zh-CN.json file and an en.json file to place the Chinese and English translated texts respectively.

zh-CN.json file example:

{
  "hello": "你好",
  "welcome": "欢迎使用",
  "button": {
    "submit": "提交",
    "cancel": "取消"
  },
  ...
}

en.json file example:

{
  "hello": "Hello",
  "welcome": "Welcome",
  "button": {
    "submit": "Submit",
    "cancel": "Cancel"
  },
  ...
}

3. Use internationalized text in Vue components
When internationalization is required In the Vue component that is processed, we can use Vue's built-in instructions or filters to obtain the corresponding translated text.

Example of using Vue built-in instructions:

<template>
  <div>
    <h2>{{ $t('hello') }}</h2>
    <p>{{ $t('welcome') }}</p>
    <button @click="submit">{{ $t('button.submit') }}</button>
    <button @click="cancel">{{ $t('button.cancel') }}</button>
  </div>
</template>

<script>
export default {
  name: 'MyComponent',
  methods: {
    submit() {
      // 提交操作
    },
    cancel() {
      // 取消操作
    }
  }
}
</script>

Example of using Vue filter:

<template>
  <div>
    <h2>{{ 'hello' | t }}</h2>
    <p>{{ 'welcome' | t }}</p>
    <button @click="submit">{{ 'button.submit' | t }}</button>
    <button @click="cancel">{{ 'button.cancel' | t }}</button>
  </div>
</template>

<script>
export default {
  name: 'MyComponent',
  filters: {
    t(key) {
      return this.$t(key)
    }
  },
  methods: {
    submit() {
      // 提交操作
    },
    cancel() {
      // 取消操作
    }
  }
}
</script>

4. Switching languages
The last step is to implement the function of switching languages. This can be achieved by adding a button or drop-down menu to switch languages.

Example:

<template>
  <div>
    <button @click="changeLocale('zh-CN')">中文</button>
    <button @click="changeLocale('en')">English</button>
  </div>
</template>

<script>
export default {
  name: 'LanguageSwitcher',
  methods: {
    changeLocale(locale) {
      this.$i18n.locale = locale
    }
  }
}
</script>

Summary:
This article introduces how to use Vue and Element-UI for international multi-language processing. By installing and introducing relevant dependent libraries, creating language pack files, and using internationalized text in Vue components, we can achieve multi-language adaptation of websites and applications. I hope this article will be helpful to you in international multi-language processing.

The above is the detailed content of How to use Vue and Element-UI for international multi-language processing. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn