update 升级@intlify/unplugin-vue-i18n版本依赖
update i18n使用方法。 add 新增i18n vite插件。
This commit is contained in:
		| @ -45,8 +45,8 @@ | |||||||
|     "vue-types": "5.1.1" |     "vue-types": "5.1.1" | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "@iconify/json": "2.2.157", |     "@iconify/json": "2.2.167", | ||||||
|     "@intlify/unplugin-vue-i18n": "1.6.0", |     "@intlify/unplugin-vue-i18n": "2.0.0", | ||||||
|     "@types/crypto-js": "4.2.0", |     "@types/crypto-js": "4.2.0", | ||||||
|     "@types/file-saver": "2.0.5", |     "@types/file-saver": "2.0.5", | ||||||
|     "@types/js-cookie": "3.0.5", |     "@types/js-cookie": "3.0.5", | ||||||
| @ -82,9 +82,9 @@ | |||||||
|     "unplugin-vue-setup-extend-plus": "1.0.0", |     "unplugin-vue-setup-extend-plus": "1.0.0", | ||||||
|     "vite-plugin-compression": "0.5.1", |     "vite-plugin-compression": "0.5.1", | ||||||
|     "vite-plugin-svg-icons": "2.0.1", |     "vite-plugin-svg-icons": "2.0.1", | ||||||
|     "vitest": "0.29.7", |     "vitest": "1.1.3", | ||||||
|     "vue-eslint-parser": "9.3.2", |     "vue-eslint-parser": "9.3.2", | ||||||
|     "vue-tsc": "0.35.0", |     "vue-tsc": "1.8.27", | ||||||
|     "vite": "5.0.10" |     "vite": "5.0.10" | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | |||||||
| @ -1,5 +1,5 @@ | |||||||
| <template> | <template> | ||||||
|   <el-config-provider :locale="appStore.locale" :size="size"> |   <el-config-provider :locale="appStore.locale" :size="appStore.size"> | ||||||
|     <router-view /> |     <router-view /> | ||||||
|   </el-config-provider> |   </el-config-provider> | ||||||
| </template> | </template> | ||||||
| @ -10,7 +10,6 @@ import { handleThemeStyle } from '@/utils/theme'; | |||||||
| import useAppStore from '@/store/modules/app'; | import useAppStore from '@/store/modules/app'; | ||||||
|  |  | ||||||
| const appStore = useAppStore(); | const appStore = useAppStore(); | ||||||
| const size = computed(() => appStore.size); |  | ||||||
|  |  | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|   nextTick(() => { |   nextTick(() => { | ||||||
|  | |||||||
							
								
								
									
										25
									
								
								src/lang/en_US.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								src/lang/en_US.json
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,25 @@ | |||||||
|  | { | ||||||
|  |   "route": { | ||||||
|  |     "dashboard": "Dashboard", | ||||||
|  |     "document": "Document" | ||||||
|  |   }, | ||||||
|  |   "login": { | ||||||
|  |     "username": "Username", | ||||||
|  |     "password": "Password", | ||||||
|  |     "login": "Login", | ||||||
|  |     "code": "Verification Code", | ||||||
|  |     "copyright": "" | ||||||
|  |   }, | ||||||
|  |   "navbar": { | ||||||
|  |     "full": "Full Screen", | ||||||
|  |     "language": "Language", | ||||||
|  |     "dashboard": "Dashboard", | ||||||
|  |     "document": "Document", | ||||||
|  |     "message": "Message", | ||||||
|  |     "layoutSize": "Layout Size", | ||||||
|  |     "selectTenant": "Select Tenant", | ||||||
|  |     "layoutSetting": "Layout Setting", | ||||||
|  |     "personalCenter": "Personal Center", | ||||||
|  |     "logout": "Logout" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @ -1,19 +1,8 @@ | |||||||
| // 自定义国际化配置 | // 自定义国际化配置 | ||||||
| import { createI18n } from 'vue-i18n'; | import { createI18n } from 'vue-i18n'; | ||||||
|  |  | ||||||
| // 本地语言包 |  | ||||||
| import enUSLocale from './en_US'; |  | ||||||
| import zhCNLocale from './zh_CN'; |  | ||||||
| import { LanguageEnum } from '@/enums/LanguageEnum'; | import { LanguageEnum } from '@/enums/LanguageEnum'; | ||||||
|  | import messages from '@intlify/unplugin-vue-i18n/messages'; | ||||||
| const messages = { |  | ||||||
|   zh_CN: { |  | ||||||
|     ...zhCNLocale |  | ||||||
|   }, |  | ||||||
|   en_US: { |  | ||||||
|     ...enUSLocale |  | ||||||
|   } |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * 获取当前语言 |  * 获取当前语言 | ||||||
| @ -28,6 +17,7 @@ export const getLanguage = (): LanguageEnum => { | |||||||
| }; | }; | ||||||
|  |  | ||||||
| const i18n = createI18n({ | const i18n = createI18n({ | ||||||
|  |   globalInjection: true, | ||||||
|   legacy: false, |   legacy: false, | ||||||
|   locale: getLanguage(), |   locale: getLanguage(), | ||||||
|   messages |   messages | ||||||
|  | |||||||
							
								
								
									
										25
									
								
								src/lang/zh_CN.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								src/lang/zh_CN.json
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,25 @@ | |||||||
|  | { | ||||||
|  |   "route": { | ||||||
|  |     "dashboard": "首页", | ||||||
|  |     "document": "项目文档" | ||||||
|  |   }, | ||||||
|  |   "login": { | ||||||
|  |     "username": "用户名", | ||||||
|  |     "password": "密码", | ||||||
|  |     "login": "登 录", | ||||||
|  |     "code": "请输入验证码", | ||||||
|  |     "copyright": "" | ||||||
|  |   }, | ||||||
|  |   "navbar": { | ||||||
|  |     "full": "全屏", | ||||||
|  |     "language": "语言", | ||||||
|  |     "dashboard": "首页", | ||||||
|  |     "document": "项目文档", | ||||||
|  |     "message": "消息", | ||||||
|  |     "layoutSize": "布局大小", | ||||||
|  |     "selectTenant": "选择租户", | ||||||
|  |     "layoutSetting": "布局设置", | ||||||
|  |     "personalCenter": "个人中心", | ||||||
|  |     "logout": "退出登录" | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										6
									
								
								vite/plugins/i18n.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								vite/plugins/i18n.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,6 @@ | |||||||
|  | import VueI18nPlugin from '@intlify/unplugin-vue-i18n/vite'; | ||||||
|  | export default (path: any) => { | ||||||
|  |   return VueI18nPlugin({ | ||||||
|  |     include: [path.resolve(__dirname, '../../src/lang/**.json')] | ||||||
|  |   }); | ||||||
|  | }; | ||||||
| @ -6,6 +6,7 @@ import createIcons from './icons'; | |||||||
| import createSvgIconsPlugin from './svg-icon'; | import createSvgIconsPlugin from './svg-icon'; | ||||||
| import createCompression from './compression'; | import createCompression from './compression'; | ||||||
| import createSetupExtend from './setup-extend'; | import createSetupExtend from './setup-extend'; | ||||||
|  | import createI18n from './i18n'; | ||||||
| import path from 'path'; | import path from 'path'; | ||||||
|  |  | ||||||
| export default (viteEnv: any, isBuild = false): [] => { | export default (viteEnv: any, isBuild = false): [] => { | ||||||
| @ -18,5 +19,6 @@ export default (viteEnv: any, isBuild = false): [] => { | |||||||
|   vitePlugins.push(createIcons()); |   vitePlugins.push(createIcons()); | ||||||
|   vitePlugins.push(createSvgIconsPlugin(path, isBuild)); |   vitePlugins.push(createSvgIconsPlugin(path, isBuild)); | ||||||
|   vitePlugins.push(createSetupExtend()); |   vitePlugins.push(createSetupExtend()); | ||||||
|  |   vitePlugins.push(createI18n(path)); | ||||||
|   return vitePlugins; |   return vitePlugins; | ||||||
| }; | }; | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	 LiuHao
					LiuHao