vue-i18n中英切换插件使用
2019-02-14 本文已影响0人
周郭郭先生
虽然现在的浏览器都能实现翻译功能,但没有什么是比甲方爸爸说话更有权威的了。
问:如果实现后端数据传送前端时中英切换?
答:可以通过请求头设置一个为lang的值传送给后台,然后后台对lang=1进行判断,如果值为1表示英文。如果没有值,表示中文,然后进行数据的更改传送。
问:那不是后台传送的数据呢?
答:可通过vue-i8n插件实现。
问:如何通过按钮点击或者时间触发进行中英切换?
答:可以设置h5本地储存,触发事件时将lang进行更改。
问:为什么要用h5本地储存?
答;cookie也可以,看个人习惯。
1、安装
npm install vue-i18n 或 yarn add vue-i18n
2、建新utils文件夹并建新storage.js用于储存当前语言标识符
data:image/s3,"s3://crabby-images/29aa0/29aa04f7a633b309ee72c5ab0fae931eee113518" alt=""
data:image/s3,"s3://crabby-images/50fd7/50fd707e13adde5a9fc0bf7a2b4d614f82ce63bf" alt=""
3、在src文件夹中建新i18n文件夹
data:image/s3,"s3://crabby-images/30e9d/30e9da0ee82073f2dd37a1b40335e17a658abe2d" alt=""
4、index.js中添加代码
data:image/s3,"s3://crabby-images/a86a4/a86a4b641c3504e2d92da283bca1af3903b1ec5d" alt=""
5、cn.js中以下代码
data:image/s3,"s3://crabby-images/d9f6c/d9f6cb1ec4d33f7c8850bf2f174e8230cdfbed51" alt=""
6、en.js中以下代码
data:image/s3,"s3://crabby-images/282d7/282d77aae2f01540dd2ef812ef43ea48ce012ef4" alt=""
注:en.js与cn.js对象中的key一定要对应,否则会出错
7、在main.js中挂载i18n
data:image/s3,"s3://crabby-images/fb17c/fb17ca8b40c84fc4276d96881be98d733882b8fe" alt=""
8、在项目中如何运用
template标签中使用
data:image/s3,"s3://crabby-images/6225e/6225e2d6774053e7a22a73074492c3be4bfc7faf" alt=""
script标签中使用
data:image/s3,"s3://crabby-images/ae8cc/ae8cc8dbb6f5e7b138b959aa537fa7706d66be9c" alt=""
9、axios设置请求头
data:image/s3,"s3://crabby-images/15730/157303a5c276ea766fbf4ac6bc0ee5efdc378ca3" alt=""
10、触发事件切换中英文
事件触发后进行页面刷新,不然无法触发ajax请求,那后台就不能切换后的数据重新发过来,加上time参数是为了个别优化。
data:image/s3,"s3://crabby-images/3b8c3/3b8c3ba918041e31a93a70659119b434849b0951" alt=""