当前位置: 首页 > article >正文

Vue 3 国际化实战:支持 Element Plus 组件和语言持久化

目录

  • Vue 3 国际化实战:支持 Element Plus 组件和语言持久化
    • 实现效果:
      • 效果一、中英文切换
      • 效果二、本地持久化存储
      • 效果三、element Plus国际化
    • vue3项目国际化实现步骤
      • 第一步、安装`i18n`
      • 第二步、配置`i18n`的`en`和`zh`
      • 第三步:使用 `vue-i18n` 库来实现多语言支持
      • 第四步、本地持久化
      • 第五步、main.ts挂载
      • 第六步、页面使用测试效果
      • 第七步、 `Element Plus`的国际化操作
      • 第八步、element Plus国际化效果测试
    • 问题总结:
      • 问题一、如何在js种使用
      • 问题二、elementPlud表单校验提示不生效问题

Vue 3 国际化实战:支持 Element Plus 组件和语言持久化

i18n来源于英文单词internationalization的首末字母in,18为中间的字符数,是"国际化"的简称,在资迅领域,国际化(i18n)指产品,出版物,软件,硬件等无需做大的改变就能适应不同的语言和地区的需要,对前端开发来说,在不修改内部代码的情况下,能根据不同语言及地区显示相应的界面,在全球化时代,国际化尤为重要,因为产品的潜在用户可能来自世界各个国家,通常与i18n相关的还有L10n本地化的简称。

实现效果:

效果一、中英文切换

Vue 3 国际化实战:支持 Element Plus 组件和语言持久化

效果二、本地持久化存储

Vue 3 国际化实战:支持 Element Plus 组件和语言持久化

效果三、element Plus国际化

Vue 3 国际化实战:支持 Element Plus 组件和语言持久化

vue3项目国际化实现步骤

第一步、安装i18n

vue3中需要安装的版本是v9版本

 npm install vue-i18n@9

Vue 3 国际化实战:支持 Element Plus 组件和语言持久化
Vue 3 国际化实战:支持 Element Plus 组件和语言持久化

第二步、配置i18nenzh

  1. 创建src/locales/en.json
    {"header": {"title": "JuBo Vision · AI Intelligent Inspection System","home": "Home","systemConfiguration": "System Configuration","inspectionSettings": "Inspection Settings","faultConfiguration": "Fault Configuration","logs": "Logs"}
    }
    
  2. 创建src/locales/zh.json
    	{"header": {"title": "聚玻Vision ·AI智能检测系统","home": "首页","systemConfiguration": "系统配置","inspectionSettings": "检测配置","faultConfiguration": "故障配置","logs": "日志"}
    }
    

第三步:使用 vue-i18n 库来实现多语言支持

创建src/locales/index.ts,其中代码步骤:

  1. vue-i18n中导入用于创建 i18n 实例的方法。
  2. 分别导入中文和英文的语言资源文件(enzhJSON 格式)。
  3. 通过navigator.language获取用户语言环境。
  4. 检查本地缓存的语言设置,如果本地存储中有值,则解析 JSON 数据并提取 curLocale 字段作为当前语言。
  5. 创建 i18n 实例。
  6. 定义支持的语言列表。

整体代码:

import { createI18n } from 'vue-i18n'
import zh from './zh.json'
import en from './en.json'// 获取浏览器界面语言,默认语言
let currentLanguage = navigator.language.replace(/-(\S*)/, '')// 如果本地缓存记录了语言环境,则使用本地缓存
let lsLocale = localStorage.getItem('locale') || ''
if (lsLocale) {currentLanguage = JSON.parse(lsLocale)?.curLocale
}export const i18n = createI18n({locale: currentLanguage,legacy: false, // 修复组件引入i18n时vite脚手架报错的问题globalInjection: true, // 全局注册 $tmessages: {zh,en}
})export const langs = [{ key: 'zh', title: '中文' },{ key: 'en', title: 'English' }
]

第四步、本地持久化

当我们把中文改成English后,再刷新页面,语言环境又会回到中文,所以我们需要做一点工作来保持国际化状态。
创建src/stores/locales.ts文件,代码如下:

import { defineStore } from 'pinia'
import { ref } from 'vue'
import { i18n } from '../locales/index'
export const useLocaleStore = defineStore('locale',() => {// 初始化时从 localStorage 获取语言设置,默认为 'en'const locale = ref(localStorage.getItem('user-locale') || i18n.global.locale.value);// 设置localefunction setLocale(lang: any) {locale.value = langi18n.global.locale.value = langlocalStorage.setItem('user-locale', lang); // 持久化存储到 localStorage}return { locale, setLocale }}
)

第五步、main.ts挂载

import { createApp, watch } from 'vue';
import { createPinia } from 'pinia';
import App from './App.vue';
import router from './router';
// 整合ElementPlus
import ElementPlus from 'element-plus';
// 样式文件,elemen-plus样式在index.scss中导入了
import '@/styles/index.scss';
// 图标
import { useElIcon } from '@/utils/setGlobal';
// 国际化
import { i18n } from './locales/index'
// 引入 Pinia Store
import { useLocaleStore } from './stores/locales';
const app = createApp(App);
app.use(createPinia());
app.use(router);
app.use(i18n)
app.use(ElementPlus);
// 初始化语言设置
const localeStore = useLocaleStore();
const currentLocale = localeStore.locale;
// 同步 i18n 的语言设置
localeStore.setLocale(currentLocale);
// 全局注册图标`ele-`开头(样式在index.scss中)
useElIcon(app);
app.mount('#app')

第六步、页面使用测试效果

代码:

<template><!-- 右侧头部区域 --><el-header class="layout-header"><div class="header-box"><logo /></div><divclass="header-navigation-bar"style="display: flex; justify-content: space-between"><div style="width: 50%"><el-menu:router="true":default-active="$route.path"class="el-menu-demo"mode="horizontal"@select="handleSelect"><el-menu-item index="/">{{ $t("header.home") }}</el-menu-item><el-menu-item index="/systemSetting">{{$t("header.systemConfiguration")}}</el-menu-item><el-sub-menu index="/detectionConfig"><template #title>{{ $t("header.inspectionSettings") }}</template><el-menu-item index="/detectionConfig">{{$t("header.inspectionSettings")}}</el-menu-item><el-menu-item index="/faultConfig">{{$t("header.faultConfiguration")}}</el-menu-item></el-sub-menu><el-menu-item index="/log">{{ $t("header.logs") }}</el-menu-item></el-menu></div><el-date-picker type="datetime" placeholder="Select date and time" /><div style="margin-right: 50px; height: 30px"><el-dropdown@command="handleCommand"style="width: 80px; line-height: 30px"><div class="el-dropdown-link" style="display: flex"><div>{{ currentLan }}</div><div style="line-height: 30px; line-height: 37px; margin-left: 4px"><SvgIcon name="ele-ArrowDown"></SvgIcon></div></div><template #dropdown><el-dropdown-menu><el-dropdown-itemv-for="lang in langs":key="lang.key":command="lang">{{ lang.title }}</el-dropdown-item></el-dropdown-menu></template></el-dropdown></div></div></el-header>
</template>
<script setup lang="ts" name="LayoutHeader">
import { defineAsyncComponent } from "vue";
import { ref } from "vue";//正确用法
import { langs } from "../../locales/index"; //这个是你自己的国际化配置文件import { useLocaleStore } from "../../stores/locales";
import { getCurrentInstance } from "vue";
const Logo = defineAsyncComponent(() => import("./logo.vue"));
const useLocale = useLocaleStore();const handleSelect = (key: string, keyPath: string[]) => {console.log(key, keyPath);
};
const app = getCurrentInstance();
let curLocale = useLocale.locale;
let currentLan = ref(langs.find((cur) => cur.key === curLocale)?.title || "");const handleCommand = (command: any) => {currentLan.value = command.title;// i18n.global.locale.value = command.key; // 设置初始语言useLocale.setLocale(command.key);
};
</script>
<style scoped lang="scss">
.el-menu--horizontal {--el-menu-horizontal-height: 30px;
}
.header-box {height: 52px;width: 100;background-color: white;line-height: 52px;border-bottom: 1px solid #f3f3f3;
}
.header-navigation-bar {height: 30px;width: 100%;
}
</style>

效果:Vue 3 国际化实战:支持 Element Plus 组件和语言持久化

第七步、 Element Plus的国际化操作

使用 Element Plus 提供的语言切换 APIElLocaleProviderel-config-provider 组件),可以实现 Element Plus 组件的动态国际化!你只需要在 App.vue 中包一层配置组件就可以了。

<script setup lang='ts'>
import { computed } from "vue";
import { useLocaleStore } from "./stores/locales";
import zhCn from "element-plus/es/locale/lang/zh-cn";
import en from "element-plus/es/locale/lang/en";const localeStore = useLocaleStore();
const currentLocale = computed(() => {return localeStore.locale === "zh" ? zhCn : en;
});
</script>
<template><!-- 不要少了`class="h100"` 高度100%,不然布局的高度无法占满 --><div class="h100"><!-- 路由组件渲染出品 --><!-- <router-view></router-view> --><el-config-provider :locale="currentLocale"><router-view /></el-config-provider></div>
</template>
<style scoped>
</style>

第八步、element Plus国际化效果测试

Vue 3 国际化实战:支持 Element Plus 组件和语言持久化
刷新持久化存储:
Vue 3 国际化实战:支持 Element Plus 组件和语言持久化

问题总结:

问题一、如何在js种使用

import { ElMessage } from "element-plus";
import { useI18n } from "vue-i18n";
const { t } = useI18n();
ElMessage.error(t("login.loginFail"));

问题二、elementPlud表单校验提示不生效问题

正常去写发现数据没热更新,使用了computed去写
无法热更新写法:

const loginRules = reactive<FormRules>({username: [{required: true,message: t("login.userNamePlaceholder"),trigger: "blur",},],password: [{ required: true, message: t("login.userPwdPlaceholder"), trigger: "blur" },],
});

Vue 3 国际化实战:支持 Element Plus 组件和语言持久化
直接使用computed包住整个校验后的写法:

const loginRules = computed(() => ({username: [{required: true,message: t("login.userNamePlaceholder"),trigger: "blur",},],password: [{ required: true, message: t("login.userPwdPlaceholder"), trigger: "blur" },],
}));

效果:
英文状态:
Vue 3 国际化实战:支持 Element Plus 组件和语言持久化
中文状态
Vue 3 国际化实战:支持 Element Plus 组件和语言持久化
完美解决无法热更新问题

相关文章:

Vue 3 国际化实战:支持 Element Plus 组件和语言持久化

目录 Vue 3 国际化实战&#xff1a;支持 Element Plus 组件和语言持久化实现效果&#xff1a;效果一、中英文切换效果二、本地持久化存储效果三、element Plus国际化 vue3项目国际化实现步骤第一步、安装i18n第二步、配置i18n的en和zh第三步&#xff1a;使用 vue-i18n 库来实现…...

1.阿里云快速部署Dify智能应用

一、宝塔面板 宝塔面板是一款功能强大且易于使用的服务器管理软件&#xff0c;支持Linux和Windows系统&#xff0c;通过web端可视化操作&#xff0c;优化了建站流程&#xff0c;提供安全管理、计划任务、文件管理以及软件管理等功能。 1.1 宝塔面板的特点与优势 易用性 宝塔面…...

Ubuntu与windows时间同步

由于ubuntu每次重启后时间老是不对&#xff0c;所以使用ntp服务&#xff0c;让ubuntu作为客户端&#xff0c;去同步windows时间。 一、windows服务端配置 1、启用ntp服务 # 启动W32Time服务&#xff08;若未启动&#xff09; net start w32time # 配置服务为NTP模式 w32tm /…...

在pycharm配置虚拟环境和jupyter,解决jupyter运行失败问题

记录自己pycharm环境配置和解决问题的流程。 解决pycharm无法运行jupyter代码&#xff0c;仅运行import板块显示运行失败&#xff0c;但是控制台不输出任何错误信息&#xff0c;令人困惑。 遇到的问题是&#xff1a;运行代码左下角显示运行失败但是有没有任何的输出错误信息。 …...

Vue 技术解析:从核心概念到实战应用

Vue.js 是一款流行的渐进式前端框架&#xff0c;以其简洁的 API、灵活的组件化结构和高效的响应式数据绑定而受到开发者的广泛欢迎。本文将深入解析 Vue 技术的核心概念、原理和应用场景&#xff0c;帮助开发者更好地理解和使用 Vue.js。 一、Vue 的设计哲学与核心概念 &…...

Series和 DataFrame是 Pandas 库中的两种核心数据结构

Series 和 DataFrame 是 Pandas 库中的两种核心数据结构&#xff0c;它们各有特点和用途。理解它们之间的区别有助于更高效地进行数据分析和处理。以下是 Series 和 DataFrame 的主要区别&#xff1a; 1. 维度 Series&#xff1a;是一维的数组&#xff0c;可以存储任何类型的…...

关于异步消息队列的详细解析,涵盖JMS模式对比、常用组件分析、Spring Boot集成示例及总结

以下是关于异步消息队列的详细解析&#xff0c;涵盖JMS模式对比、常用组件分析、Spring Boot集成示例及总结&#xff1a; 一、异步消息核心概念与JMS模式对比 1. 异步消息核心组件 组件作用生产者发送消息到消息代理&#xff08;如RabbitMQ、Kafka&#xff09;。消息代理中间…...

利用 Python 进行股票数据可视化分析

在金融市场中&#xff0c;股票数据的可视化分析对于投资者和分析师来说至关重要。通过可视化&#xff0c;我们可以更直观地观察股票价格的走势、交易量的变化以及不同股票之间的相关性等。 Python 作为一种功能强大的编程语言&#xff0c;拥有丰富的数据处理和可视化库&#xf…...

【Docker】离线安装Docker

背景 离线安装Docker的必要性&#xff0c;第一&#xff0c;在目前数据安全升级的情况下&#xff0c;很多外网已经基本不好访问了。第二&#xff0c;如果公司有对外部署的需求&#xff0c;那么难免会存在对方只有内网的情况&#xff0c;那么我们就要做到学会离线安装。 下载安…...

kubectl命令补全以及oc命令补全

kubectl命令补全 1.安装bash-completion 如果你用的是Bash(默认情况下是)&#xff0c;先安装补全功能支持包 sudo apt update sudo apt install bash-completion -y2.为kubectl 启用补全功能 会话中临时&#xff1a; source <(kubectl completion bash)持久化配置&#x…...

《 C++ 点滴漫谈: 三十三 》当函数成为参数:解密 C++ 回调函数的全部姿势

一、前言 在现代软件开发中&#xff0c;“解耦” 与 “可扩展性” 已成为衡量一个系统架构优劣的重要标准。而在众多实现解耦机制的技术手段中&#xff0c;“回调函数” 无疑是一种高效且广泛使用的模式。你是否曾经在编写排序算法时&#xff0c;希望允许用户自定义排序规则&a…...

极简cnn-based手写数字识别程序

1.先看看识别效果&#xff1a; 这个程序识别的是0~9的一组手写数字&#xff0c;这是最终的识别效果&#xff0c;为1&#xff0c;代表识别成功&#xff0c;0为失败。 然后数据源是&#xff1a;ds deeplake.load(hub://activeloop/optical-handwritten-digits-train)里面是一组…...

C++核心机制-this 指针传递与内存布局分析

示例代码 #include<iostream> using namespace std;class A { public:int a;A() {printf("A:A()的this指针&#xff1a;%p!\n", this);}void funcA() {printf("A:funcA()的this指针&#xff1a;%p!\n", this);} };class B { public:int b;B() {prin…...

vue3 history路由模式刷新页面报错问题解决

在使用history路由模式时刷新网页提示404错误&#xff0c;这是改怎么办呢。 官方解决办法 https://router.vuejs.org/zh/guide/essentials/history-mode.html...

PHP爬虫教程:使用cURL和Simple HTML DOM Parser

一个关于如何使用PHP的cURL和HTML解析器来创建爬虫的教程&#xff0c;特别是处理代理信息的部分。首先&#xff0c;我需要确定用户的需求是什么。可能他们想从某个网站抓取数据&#xff0c;但遇到了反爬措施&#xff0c;需要使用代理来避免被封IP。不过用户没有提到具体的目标网…...

Web前端开发——格式化文本与段落(上)

一、学习目标 网页内容的排版包括文本格式化、段落格式化和整个页面的格式化&#xff0c;这是设计个网页的基础。文本格式化标记分为字体标记、文字修饰标记。字体标记和文字修饰标记包括对于字体样式的一些特殊修改。段落格式化标记分为段落标记、换行记、水平分隔线标记等。…...

技术方案选型要考虑哪些点?

在概要设计阶段&#xff0c;技术方案选型是核心环节之一&#xff0c;需综合考虑系统需求、技术可行性、团队能力及长期维护成本。以下是技术方案选型需包含的核心内容及设计要点&#xff0c;结合行业实践和搜索结果中的方法论&#xff1a; 理论 一、系统架构选型 整体架构模式…...

前端工程化之自动化构建

自动化构建 自动化构建的基本知识历史云构建 和 自动化构建 的区别&#xff1a;部署环境&#xff1a;构建&#xff1a;构建产物构建和打包的性能优化页面加载优化构建速度优化 DevOps原则反馈的技术实践 encode-bundlepackage.json解读src/cli-default.tssrc/cli-node.tssrc/cl…...

3.2.2.1 Spring Boot配置静态资源映射

在Spring Boot中配置静态资源映射&#xff0c;可以通过默认路径或自定义配置实现。默认情况下&#xff0c;Spring Boot会在classpath:/static/等目录下查找静态资源。若需自定义映射&#xff0c;可通过实现WebMvcConfigurer接口的addResourceHandlers方法或在全局配置文件中设置…...

# 更换手机热点后secureCRT无法连接centOS7系统

更换手机热点后secureCRT无法连接centOS7系统 一、问题描述 某些情况下&#xff0c;我们可能使用手机共享热点而给电脑联网。本来用一个手机热点共享网络时&#xff0c;SecureCRT可以正常连接到CentOS 7虚拟机&#xff0c;当更换一个手机热点时&#xff0c;突然发现SecureCR…...

【高性能缓存Redis_中间件】三、redis 精通:性能优化与生产实践

一、引言​ 在前两篇 Redis 消息队列的文章中&#xff0c;我们掌握了基础使用和高级特性。本文作为系列终篇&#xff0c;将聚焦生产环境的性能优化与全流程实践&#xff0c;请各位跟随小编的步伐一起构建高可靠、高性能的消息处理系统&#xff08;文章中的演示均为Centos7的背…...

jupyter notebook 无法启动- markupsafe导致

一、运行jupyter notebook和Spyder报错&#xff1a;(已安装了Anaconda&#xff0c;以前可打开) 1.背景&#xff1a;为了部署机器学习模型&#xff0c;按教程直接安装了flask 和markupsafe&#xff0c;导致jupyter notebook&#xff0c;Spyder 打不开。 pip install flas…...

Kotlin作用域函数

在 Kotlin 中&#xff0c;.apply 是一个 作用域函数&#xff08;Scope Function&#xff09;&#xff0c;它允许你在一个对象的上下文中执行代码块&#xff0c;并返回该对象本身。它的设计目的是为了 对象初始化 或 链式调用 时保持代码的简洁性和可读性。 // 不使用 apply va…...

设计模式:工厂方法模式 - 高扩展性与低耦合的设计之道

一、为什么需要工厂方法模式&#xff1f; 在软件开发中&#xff0c;对象创建与使用耦合会影响系统的灵活性和扩展性。以通知系统&#xff08;支持邮件通知、短信通知和推送通知&#xff09;为例 &#xff1a;直接实例化。 Notification email new EmailNotification(); Noti…...

CTF web入门之命令执行 完整版

web29 文件名过滤 由于flag被过滤,需要进行文件名绕过,有以下几种方法: 1.通配符绕过 fla?.* 2.反斜杠绕过 fl\ag.php 3.双引号绕过 fl’‘ag’.php 还有特殊变量$1、内联执行等 此外 读取文件利用cat函数,输出利用system、passthru 、echo echo `nl flag.php`; ec…...

自然语言处理spaCy

spaCy 是一个流行的开源 自然语言处理&#xff08;NLP&#xff09; 库&#xff0c;专注于 高效、易用和工业化应用。它由 Explosion AI 开发&#xff0c;广泛应用于文本处理、信息提取、机器翻译等领域。 zh_core_web_sm 是 spaCy 提供的一个小型中文预训练语言模型&#xff0…...

在spark中,窄依赖算子map和filter会组合为一个stage,这种情况下,map和filter是在一个task内进行的吗?

在 Spark 中&#xff0c;当 map 和 filter 这类窄依赖&#xff08;Narrow Dependency&#xff09;的算子连续应用时&#xff0c;它们会被合并到同一个 Stage 中&#xff0c;并且在同一个 Task 内按顺序执行。这种优化称为 流水线&#xff08;Pipeline&#xff09;执行&#xff…...

MySQL切换PolarDB-X方案

一、DTS 增量同步完成后的流量切换策略 1. 切换期间的数据写入处理 • 场景&#xff1a;DTS 增量同步完成&#xff08;Lag0&#xff09;后&#xff0c;业务流量切换到 PolarDB-X 的瞬间可能产生 2-3 秒延迟&#xff0c;导致部分订单仍写入 MySQL。 • 解决方案&#xff1a; ◦…...

Java 开发工具:从 Eclipse 到 IntelliJ IDEA 的进化之路

Java 开发工具&#xff1a;从 Eclipse 到 IntelliJ IDEA 的进化之路 在 Java 开发的历史长河中&#xff0c;开发工具的演变不仅改变了程序员的编码方式&#xff0c;也深刻影响了整个行业的开发效率和代码质量。从 Eclipse 到 IntelliJ IDEA&#xff0c;这不仅是工具的更替&…...

GPT - 2 文本生成任务全流程

数据集下载 数据预处理 import json import pandas as pdall_data []with open("part-00018.jsonl",encoding"utf-8") as f:for line in f.readlines():data json.loads(line)all_data.append(data["text"])batch_size 10000for i in ran…...