温馨提示×

温馨提示×

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

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

vue怎么使用vue-i18n做全局中英文切换

发布时间:2021-04-24 17:07:04 来源:亿速云 阅读:381 作者:小新 栏目:web开发

小编给大家分享一下vue怎么使用vue-i18n做全局中英文切换,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

为什么要使用Vue

Vue是一款友好的、多用途且高性能的JavaScript框架,使用vue可以创建可维护性和可测试性更强的代码库,Vue允许可以将一个网页分割成可复用的组件,每个组件都包含属于自己的HTML、CSS、JavaScript,以用来渲染网页中相应的地方,所以越来越多的前端开发者使用vue。

1、vue-i18n安装  

npm install vue-i18n --save-dev

2、在main.js文件中引入 

import VueI18n from 'vue-i18n';
  Vue.use(VueI18n);
  const i18n = new VueI18n({
    locale: localStorage.getItem('language')||'zh', //使用localStorage缓存到本地,当下次使用时可默认当前使用语言
    messages: {
 '      zh': require('./common/lang/zh'),
      'en': require('./common/lang/en')
    }
  })
  new Vue({
    el: '#app',
    router,
    i18n,
    template: '<App/>',
    components: { App }
  })

3、新建中英文语言文件

  zh.js:

module.exports = {

    language: {
      name: 'English'
    },
    navbar: {
      home: '首页',
    }
  }

  en.js: 

module.exports = {

    language: {
      name: '中文'
    },
    navbar: {
      home: 'Home',
    }
  }

4、创建一个切换语言方法(写在App.vue可以全局控制);

 changeLang() {
    let locale = localStorage.getItem('language')||'zh';
    let temp=locale === 'zh' ? 'en' : 'zh';
    this.$i18n.locale=temp;//改变当前语言
     localStorage.language=temp;
  }

5、在template中的使用: 

 <p>{{ $t('language.name') }}</p>
  <p>{{ $t('navbar.contact') }}</p>

看完了这篇文章,相信你对“vue怎么使用vue-i18n做全局中英文切换”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

向AI问一下细节

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

AI