vue-i18n多语言文件归类的两种方法
1.按语言类型归类
流行的做法是按照语言对文件进行归类,目录结构类似于:
--lang
----en
------test.json
--------"abc": "abc"
----zh
------test.json
--------"abc": "测试"
这样处理有个问题,就是没出添加一项,都要同时切换到两个文件中进行添加,开发起来很麻烦,
2.按功能模块分类
还有个方法就是按照功能模块分类,一个文件中包含了这个功能下的所有语言,目录结构类型下面:
--lang
----test.js
------en
--------"abc": "abc"
------zh
--------"abc": "测试"
这样的话,开发过程中,只需要关注一个文件,就能完成所有国际化设置.
3.两种方式对比
按照语言进行分类的好处,就是加载时会根据本地语言环境加载不同的语言包,不用一次性加载所有的,按照模块分类的好处就是,开发容易了,编写国际化项的时候,只关注一个文件就行了。
开发流行的还是按照语言分类,然后辅助一多语言工具来管理;
4.两种方式的实现方法
4.1按语言包实现代码
4.1.1目录结构
i18n
--en
----index.js
----common.json
--zh_CN
----index.js
----common.json
4.1.2main.js
import Vue from 'vue'
import App from './App.vue'
import i18n from './i18n' Vue.config.productionTip = false new Vue({
i18n,
render: h => h(App),
}).$mount('#app')
4.1.3 i18n/index.js
import Vue from 'vue'
import VueI18n from 'vue-i18n'
import Cookie from 'vue-cookie'
import ZH from './zh_CN'
import EN from './en' Vue.use(Cookie)
Vue.use(VueI18n) const loc = Cookie.get('lang') const i18n = new VueI18n({
locale: loc || 'zh',
messages: {
en: EN,
zh: ZH
}
}) export default i18n
4.1.4 en/index.js
import common from './common.json'
export default {
common
}
4.1.5 en/common.json
{
"webName": "User Management System",
"translations": "中文"
}
4.1.6 zh_cn/index.js
同 4.1.4 en/index.js
4.1.7 zh_cn/common.json
{
"webName": "用户管理系统",
"translations": "English"
}
以上是按照语言格式进行多文件分类的实现,下面是按照功能模块进行多文件分类的实现
4.2 按功能模块进行文件分类
4.2.1 目录结构
i18n
--index.js
--login.js
--test.js
4.2.2 main.js
同 4.1.2 main.js
4.2.2 i18n/index.js
import Vue from 'vue'
import VueI18n from 'vue-i18n'
import {zh as loginZh, en as loginEn} from './login'
import {zh as testZh, en as testEn} from './test' Vue.use(VueI18n) let EN = {
login: loginEn,
test: testEn
}
let ZH = {
login: loginZh,
test: testZh
} const i18n = new VueI18n({
locale: 'zh',
messages: {
en: EN,
zh: ZH
}
}) export default i18n
4.2.3 i18n/login.js
export const en = {
"title": "title"
}
export const zh = {
"title": "标题"
}
4.2.4 i18n/test.js
export const en = {
"title": "title",
"err": "error"
}
export const zh = {
"title": "标题",
"err": "错误信息"
}
vue-i18n多语言文件归类的两种方法的更多相关文章
- PDF怎么转换为CAD文件?这两种方法你的会
在日常的办公中,我们最常见的文件格式就是PDF格式的,因为PDF文件的安全性是比较高的,可以防止不小心触碰到键盘修改文件内容,而且PDF文件便于进行文件的传输.但是有时候也需要将PDF转换成CAD,那 ...
- Oracle导出表(即DMP文件)的两种方法
转载:http://blog.csdn.net/lanpy88/article/details/7580691 方法一:利用PL/SQL Developer工具导出: 菜单栏---->Too ...
- upload控件上传json文件合并的两种方法
方法一: byte[] byte1 = FileUpload1.FileBytes; byte[] byte2 = FileUpload2.FileBytes; byte[] a1 = Encodin ...
- C#根据字体名通过注册表获取该字体文件路径(win10)两种方法推荐第二种
方法一: 直接先上源码: private System.Collections.Generic.SortedDictionary<string, string> ReadFontInfor ...
- java写文件时往末尾追加文件(而不是覆盖原文件),的两种方法总结
代码如下: import java.io.FileWriter; import java.io.IOException; import java.io.RandomAccessFile; public ...
- Java遍历文件夹的两种方法(非递归和递归)
import java.io.File; import java.util.LinkedList; public class FileSystem { public static int num ...
- android获取文件getMimeType的两种方法
方法1: import java.util.Locale; private static String getSuffix(File file) { if (file == null || !file ...
- python语言实现阶乘的两种方法---递归和迭代
阶乘的递归实现,代码如下: def factorial(n): if n==1: return 1 else: return n*factorial(n-1) number = int(input(& ...
- vue路由跳转传参的两种方法
路由跳转: this.$router.push({ name: '工单列表', params: {p_camera_dev_name: 'xxx'} }); 使二级菜单呈点击状态: $('[index ...
随机推荐
- 吴裕雄 Bootstrap 前端框架开发——Bootstrap 表格:在 <tbody> 内的任一行启用鼠标悬停状态
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- aws-ec2-upload
EC2上建立文件夹并开放权限 $ mkdir /home/upload$ chmod 777 /home/upload 本机文件 上传 到EC2服务器$ scp -i awsub01.pem noip ...
- 「CH6101」最优贸易
「CH6101」最优贸易 传送门 考虑一种贪心的思想:我们要尽量买价格小的货物,并尽量高价转卖. 我们记 : \(mn[i]\) 为从点 \(1\) 走到点 \(i\) 经过的价格最小的货物的价格. ...
- SpringBoot--⼯具表达式对象
⼯具表达式对象除了这些基本的对象之外,Thymeleaf将为我们提供⼀组⼯具对象,这些对象将帮助我们在表达式中执⾏常⻅任务.#execInfo:有关正在处理的模板的信息.#messages:⽤于在变量 ...
- LeetCode刷题--21.合并两个有序链表(简单)
题目描述 将两个有序链表合并为一个新的有序链表并返回.新链表是通过拼接给定的两个链表的所有节点组成的. 示例: 输入:1 -> 2 -> 4 ,1 -> 3 -> 4 输出:1 ...
- jeDate日期控件精确到秒
案例下载 链接: https://pan.baidu.com/s/1m7eEW6K6Bt1t-0OjVY_Wxw 密码: xmei <script type="text/javascr ...
- java并发:初探sleep方法
sleep与wait sleep是Thread方法,使得当前线程从运行态变为阻塞态.但它不会释放对象的锁. wait方法是Object方法,它的作用是使得当前拥有对象锁的线程从运行态变为阻塞态, 它会 ...
- JS 自动返回每个月的天数
);//M代表月份,可以自己手动设置或者选择 date.setDate() var num = date.getDate(); console.log(num) //输出每个月的天数 var time ...
- 小程序本地存储之wx.getStorageSync
这个主要可以解决微信小程序的记录缓存,入输入框的搜索历史记录 直接上代码 setsearchMsg:function(){ var that=this if (this.data.inputValue ...
- js 保留两位小数 input要求是数字框,
要求:input文本框只能输入数字,且只保留两位小数 问题:若设置input的 type="number" ,js处理部分若用到parseFloat方法处理,结果是string类 ...