前端国际化实现:别再只支持中文了

前端国际化实现:别再只支持中文了

前端国际化实现:别再只支持中文了

毒舌时刻

这代码写得跟网红滤镜似的——仅供参考。

各位前端同行,咱们今天聊聊前端国际化。别告诉我你的应用只支持中文,那感觉就像只卖一种口味的冰淇淋——单调又无趣。

为什么你需要国际化

最近看到一个项目,所有文本都硬编码在代码里,要支持英文时傻眼了,我差点当场去世。我就想问:你是在开发应用还是在开发中文专用软件?

反面教材

// 反面教材:硬编码文本 function LoginForm() { return ( <form> <h1>登录</h1> <input placeholder="请输入邮箱" /> <input placeholder="请输入密码" type="password" /> <button>登录</button> <p>还没有账号?<a href="/register">立即注册</a></p> </form> ); } 

毒舌点评:这代码,我看了都替你的海外用户着急。硬编码中文,你是想让外国用户看天书吗?

前端国际化的正确姿势

1. 使用i18next

// 正确姿势:使用i18next // i18n/index.js import i18n from 'i18next'; import { initReactI18next } from 'react-i18next'; import zh from './locales/zh.json'; import en from './locales/en.json'; i18n .use(initReactI18next) .init({ resources: { zh: { translation: zh }, en: { translation: en } }, lng: 'zh', fallbackLng: 'zh', interpolation: { escapeValue: false } }); export default i18n; // locales/zh.json { "login": { "title": "登录", "email": "请输入邮箱", "password": "请输入密码", "button": "登录", "noAccount": "还没有账号?", "register": "立即注册" } } // locales/en.json { "login": { "title": "Login", "email": "Please enter email", "password": "Please enter password", "button": "Login", "noAccount": "No account?", "register": "Register now" } } // 使用 import { useTranslation } from 'react-i18next'; function LoginForm() { const { t, i18n } = useTranslation(); const changeLanguage = (lng) => { i18n.changeLanguage(lng); }; return ( <form> <h1>{t('login.title')}</h1> <input placeholder={t('login.email')} /> <input placeholder={t('login.password')} type="password" /> <button>{t('login.button')}</button> <p> {t('login.noAccount')} <a href="/register">{t('login.register')}</a> </p> <button onClick={() => changeLanguage('zh')}>中文</button> <button onClick={() => changeLanguage('en')}>English</button> </form> ); } 

2. Vue3中使用vue-i18n

// 正确姿势:Vue3国际化 // i18n/index.js import { createI18n } from 'vue-i18n'; const messages = { zh: { message: { hello: '你好', welcome: '欢迎, {name}!' } }, en: { message: { hello: 'Hello', welcome: 'Welcome, {name}!' } } }; const i18n = createI18n({ locale: 'zh', fallbackLocale: 'en', messages }); export default i18n; // main.js import { createApp } from 'vue'; import App from './App.vue'; import i18n from './i18n'; const app = createApp(App); app.use(i18n); app.mount('#app'); // 使用 <template> <p>{{ $t('message.hello') }}</p> <p>{{ $t('message.welcome', { name: '张三' }) }}</p> <button @click="$i18n.locale = 'en'">English</button> </template> 

毒舌点评:早这么国际化,你的应用早就走向国际了。别告诉我你还只支持中文,那你还是趁早去开发国内市场吧。

实战技巧:国际化指南

1. 国际化最佳实践

  1. 提前规划:项目初期就考虑国际化
  2. 提取文本:所有用户可见文本都要提取
  3. 格式化:日期、数字、货币都要本地化
  4. RTL支持:阿拉伯语等从右到左的语言

2. 常用工具

  • i18next:React国际化
  • vue-i18n:Vue国际化
  • FormatJS:格式化库
  • react-intl:React国际化

最后想说的

国际化不是可选项,是必选项。别再只支持中文了——国际化一下,你的应用会走向更广阔的市场。

国际化就像学外语,一开始觉得麻烦,但学会后世界大门就打开了。别做井底之蛙,做世界公民。

Read more

数据库管理-第402期 不会代码的DBA做一个简单的前端系统(20260122)

数据库管理-第402期 不会代码的DBA做一个简单的前端系统(20260122)

数据库管理402期 2026-01-22 * 数据库管理-第402期 不会代码的DBA做一个简单的前端系统(20260122) * 1 进入Supabase * 2 准备环境 * 建表 * 3 项目实战 * 3.1 创建Recat项目 * 3.2 连接Supabase * 3.3 调整页面 * 3.4 功能验证 * 3.5 增加功能 * 插曲 * 总结 数据库管理-第402期 不会代码的DBA做一个简单的前端系统(20260122) 作者:胖头鱼的鱼缸(尹海文) Oracle ACE Pro: Database PostgreSQL ACE 10年数据库行业经验 拥有OCM 11g/12c/19c、MySQL 8.0 OCP、

RexUniNLU零样本NLU保姆级教程:WebUI上传文件+批量NER结果可视化

RexUniNLU零样本NLU保姆级教程:WebUI上传文件+批量NER结果可视化 1. 引言:为什么选择RexUniNLU? 如果你正在寻找一个不需要训练数据就能直接使用的自然语言理解工具,RexUniNLU可能就是你的理想选择。这个基于DeBERTa模型的零样本理解框架,最大的特点就是"开箱即用"——不需要准备任何标注数据,只需要定义好你想要抽取的内容结构,它就能自动从文本中识别出相应的信息。 想象一下这样的场景:你手头有大量文档需要提取人名、地名、组织机构名,但既没有时间也没有资源去标注训练数据。传统方法可能需要几周时间准备数据、训练模型,而RexUniNLU只需要几分钟就能开始工作。这就是零样本学习的魅力所在。 本文将手把手教你如何使用RexUniNLU的Web界面,通过上传文件的方式批量处理文本,并直观地可视化命名实体识别(NER)结果。无论你是技术小白还是有经验的开发者,都能快速上手。 2. 环境准备与快速启动 2.1 一键启动Web界面 使用RexUniNLU非常简单,只需要一条命令就能启动Web界面: python3 /root/nlp_debert

前端知识点梳理,前端面试复习

一:从输入 URL 到页面渲染是一个经典的综合性考题 1.URL 的标准组成部分 一个完整的 URL 结构如下: scheme://host:port/path?query#fragment URI 用字符串标识某一互联网资源,而URL 表示资源的地点(互 联网上所处的位置)。可见URL是URI 的子集。 URI 和 URL 的区别? * URI (Uniform Resource Identifier) 是统一资源标识符,是一个大概念。 * URL (Uniform Resource Locator) 是统一资源定位符,它不仅标识资源,还提供了找到资源的方式(比如协议)。可以理解为 URL 是 URI 的子集。 为什么 URL 中有些字符会被转义(

海景美女图FLUX.1镜像免配置:内置中文界面切换功能,支持中英双语Web UI

海景美女图FLUX.1镜像免配置:内置中文界面切换功能,支持中英双语Web UI 1. 开篇:告别复杂配置,开启AI绘画之旅 想象一下,你一直想尝试用AI生成图片,但面对复杂的安装步骤、全英文的界面和一堆看不懂的参数,是不是瞬间就打了退堂鼓?别担心,今天要介绍的这个工具,就是为你准备的。 “海景美女图 - 一丹一世界FLUX.1 AI 图像生成服务”是一个开箱即用的AI绘画工具。它的核心价值就两个字:简单。你不需要懂代码,不需要配置环境,甚至不需要懂太多英文。它已经为你准备好了一切,内置了中文界面,你只需要打开网页,输入几个词,点击一下,就能看到AI为你创作的、以海景美女为主题的图片。 这篇文章,我会带你从零开始,手把手教你如何使用这个工具。你会发现,原来让AI帮你画画,可以像点外卖一样简单。 2. 核心亮点:为什么选择这个镜像? 在众多AI绘画工具中,这个FLUX.1镜像有什么特别之处?它主要解决了三个痛点: 2.