Vue项目实战05:18n实现多语言自动切换-浏览器语言设置「建议收藏」

Vue项目实战05:18n实现多语言自动切换-浏览器语言设置「建议收藏」什么是vue-i18ni18n是Internationalization这个英文的简写,即国际化的意思,vue-i18n是一款针对于vue开发的国际化插件,让项目支持多语言切换,以适应不同地区用户的需求。安装vue-i18n直接在项目中执行安装命令:npminstallvue-i18n–save​全局引入vue-i18n在项目中引入vue-i18n,实例化vue-i18n将需要加载的语言包通过require导入,这里看个人需求我只需要中英日文,所以引入zh-CN.js和en-US.j

大家好,又见面了,我是你们的朋友全栈君。

什么是vue-i18n

i18n是 Internationalization 这个英文的简写,即国际化的意思,vue-i18n是一款针对于vue开发的国际化插件,让项目支持多语言切换,以适应不同地区用户的需求。

安装vue-i18n

直接在项目中执行安装命令:npm install vue-i18n --save
在这里插入图片描述

​全局引入vue-i18n

在项目中引入vue-i18n,实例化vue-i18n将需要加载的语言包通过require导入,这里看个人需求我只需要中英日文,所以引入zh-CN.js和en-US.js ja-JP.js,分别对应中文和英文 日文,你也可以提供多语言包,最后别忘记了将实例挂载至Vue。

步骤

1.在src下新建locale文件夹

在这里插入图片描述
在locale下建lang文件夹—-用来存放自己设置的多语言文件
index.js 入口文件
index.js里放置内容如下

import Vue from 'vue'
import VueI18n from 'vue-i18n'
import { 
    localRead } from '@/libs/util'
import { 
    Locale } from 'vant'
import customZhCn from './lang/zh-CN'
import customJaJp from './lang/ja-JP'
import customEnUs from './lang/en-US'
import zhCN from 'vant/lib/locale/lang/zh-CN'
import enUS from 'vant/lib/locale/lang/en-US'
import jaJP from 'vant/lib/locale/lang/ja-JP'

Vue.use(VueI18n)

// 自动根据浏览器系统语言设置语言
const navLang = navigator.language.substring(0, 2)
const localLang = navLang || false
let lang = localLang || localRead('local') || 'zh'

Vue.config.lang = lang

Vue.locale = () => { 
   }
const messages = { 
   
  'zh': Object.assign(zhCN, customZhCn),
  'en': Object.assign(enUS, customEnUs),
  'ja': Object.assign(jaJP, customJaJp)
}
// 实例化i18n并引入语言文件。
const i18n = new VueI18n({ 
   
  locale: lang, // 语言标识  // 默认语言
  messages
})

const vantLocales = lang => { 
   
  if (lang === 'zh') { 
   
    Locale.use(lang, zhCN)
  } else if (lang === 'en') { 
   
    Locale.use(lang, enUS)
  } else if (lang === 'ja') { 
   
    Locale.use(lang, jaJP)
  }
}
vantLocales(i18n.locale)

export default i18n

import { localRead } from '@/libs/util' 由来
在这里插入图片描述

export const localSave = (key, value) => { 
   
  localStorage.setItem(key, value)
}

export const localRead = (key) => { 
   
  return localStorage.getItem(key) || ''
}




在main.js里引入 并挂载

import i18n from '@/locale'

Vue.use(i18n)


new Vue({ 
   
  router,
  i18n, // 挂载
  render: h => h(App)
}).$mount('#app')




定义语言包

语言包已json格式书写,数据以键值对的形式呈现,所以每个语言包的键都是对应的,只是值不想同,为避免编码问题问题,我们键统一用英文,所以创建语言包的时候我们先从英文开始,搞定之后直接复制再修改对应的值就好了,最后记得export导出对象。定义数据的形式可以根据个人需求来,我喜欢把相同的放一起,这样找起来方便点。如果你觉得每次都要通过lang来获取数据比较麻烦,我们可以再优化下,把export const lang=改写成module.exports= 模式,这样就可以直接获取对象中的对象了。
Vue项目实战05:18n实现多语言自动切换-浏览器语言设置「建议收藏」

页面渲染

静态渲染时,用双大括号包裹,把数据当成变量引入,$t用来调用语言包中键对应的值。如果用的是element-ui动态绑定值,双引号即可。动态渲染时,我们可以借助计算属性,再拿这个计算属性去遍历DOM元素即可。
在这里插入图片描述
//动态渲染

computed:{ 
   
 navlist(){ 
   
 return this.$t('nav')
 }
}


以上是根据浏览器自动切换语言

点击切换

//手动切换语言
change(){ 
   
 if (this.$i18n.locale === 'zh-CN') { 
   
 this.$i18n.locale = 'en-US';
 localStorage.setItem('lang','en-US') 
 }else { 
   
 this.$i18n.locale = 'zh-CN';
 localStorage.setItem('lang','zh-CN')
 }
},

可以参考这篇文章 https://www.shangyouw.cn/shezhi/arc59448.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/135814.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • ext Window点击右上角的关闭(Xbutton)加入监控事件

    ext Window点击右上角的关闭(Xbutton)加入监控事件

  • Winform基础控件美化

    Winform基础控件美化这段时间重写了Winform的TextBox,ComboBox,NumericUpDown,DateTimePicker(还在实现中),Panel,Button控件主要实现了,这些控件的垂直居中,可自定义边框颜色等功能,支持fontawesome图标.效果见下图项目目录见下图Common是公共方法Control为继承类控件包括Button,Panel,(DateTime…

  • 电脑快速切换ip软件(好用的换ip软件)

    切换IP软件,切换电脑手机IP如此简单大家在工作和生活中肯定会时不时遇到需要换IP的情况,为了预防需要换IP的时候束手无策,小编在此给大家介绍一款专门用来换IP的软件。打开搜索引擎,不管是百度,狗搜还是360,只要在上面搜索“换IP软件”,立马就会出现非常多的换IP的品牌,有免费的也有付费的,功能都没什么区别,就是换IP。卖IP的这么多,说明换IP的市场还是非常大的!不管你是做什么行业,网络推…

  • 六个可以永久收藏的网站

    六个可以永久收藏的网站1:Aconvertaconvert.com/cnAconvert是一个完全免费并且不限转换次数的多功能文件格式转换网站,转换效果非常出色。它的功能非常强大,支持转换的文件类型包括:PDF、文档、电子书、图像、视频、音频、压缩文件。它还支持将网页转换为PDF、JPG、PNG格式。其中PDF格式转换,不仅支持将Word、Excel、PPT、HTML、TXT、DWG、JPG、PNG、GIF和TIFF文件转换为PDF,也支持将PDF文件转换为Word、Excel

  • 至少使用两种方式运行pycharm_python还是java

    至少使用两种方式运行pycharm_python还是java要!!!下了pycharm但是没下载python也是运行不了的原文链接:Python环境搭建—安利Python小白的Python和Pycharm安装详细教程-知乎工欲善其事,必先利其器。首先我们先来安装Python,在这里安利一下:其实在没有安装Python之前也可以安装Pycharm的,两者并没有什么冲突关系。但是话说回来,如果没有Python编译器,那么Pycharm其实只是个驱壳,即便你编好程序之后,也并不能运行。举个栗子,Python相当于子弹,Pycharm相当于手枪,如果手

  • 国产化替代方案_excel表格为什么替换不了

    国产化替代方案_excel表格为什么替换不了PHPExcel上一版本1.8.1于2015年发布。该项目已不再维护,可以使用,但是不建议再使用。所有用户都应该迁移到其直接后继者PhpSpreadsheet或其他替代方案。PhpSpreadsheet打破了兼容性,大大提高了代码库质量(命名空间,PSR合规性,最新PHP语言功能的使用等)。文档地址:https://phpspreadsheet.readthedocs.io/en/develo…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号