温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

vue项目中怎么实现支持多种语言

发布时间:2021-07-09 10:44:13 来源:亿速云 阅读:305 作者:Leah 栏目:大数据

这篇文章给大家介绍vue项目中怎么实现支持多种语言,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

首先咱们不妨把网页中需要转换语言的公共部分提取出来,放到一个对象中,代码如下:

const messages = {
en: {
 message: {
  hello: 'world hello'
 }
},
zh: {
 message: {
  hello: '世界'
 }
}
}

从上面的代码中可以看出,hello是一个公众变量,在中文网站中显示为“世界”,在英文网站中为“world hello”。然后通过对象的属性来区分中英文,然后将这个对象加载到全局。如何加载到全局呢,在Vue的项目中,就需要用到Vue-i18n这个模块。代码如下:

main.js

import Vue from 'vue'
import App from './App'
import VueI18n from 'vue-i18n'
const messages = {
en: {
 message: {
  hello: 'world hello'
 }
},
zh: {
 message: {
  hello: '世界'
 }
}
}
Vue.use(VueI18n)
const i18n = new VueI18n({
locale: 'zh',
messages
})
new Vue({
 i18n,
 template: '<App/>',
 components: { App },
}).$mount('#app')

  App.vue源码:

<template>
 <h2>{{$t("message.hello")}}</h2>
</template>
<script>
export default {
 created () {
   console.log(this.$t("message.hello"))
 }
}
</script>
<style>
</style>

打印结果为世界,因为在创建vue-i18n实例的过程中我们传入了两个参数,local和messages。local标识用哪国语言,local传入的是zh,messages包含着自定义的语言模块。如果local出传入的是en那打印的结果就会变成world hello。

然后在实例化组件的过程中将i18n传入,这样组件中就可以访问$t这个函数了,通过这个函数,我们可以取出messages中的属性值,将其渲染到页面中。

核心是在实例化的过程中通过local这个参数来实现实现语言的切换,message来实现语言包的加载,开发者只需将需要翻译的公共部分抽离出来放到message中即可。

关于vue项目中怎么实现支持多种语言就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI