「前端开发」JavaScript 实现国际化处理

🙏废话不多说系列,直接开整🙏


一、说明和注意事项

(1)说明和思路
  • 使用 i18next.init 初始化国际化配置,指定默认语言和资源(翻译文本),包括多个文本内容。
  • 定义 updateContent 函数,用于更新多个文本内容,调用 i18next.t 方法获取翻译文本并更新相应的 HTML 元素。
  • 为每个按钮添加事件监听器,当用户点击按钮时,调用 i18next.changeLanguage 方法切换语言,并调用 updateContent 函数更新页面内容。
(2)扩展内容
  • 多文本内容 :你可以在 resources 对象中添加更多的键值对,以支持更多的文本内容。
  • 动态内容 :如果你的网页内容是动态生成的,可以在生成内容时使用 i18next.t 进行翻译。
  • 复杂结构:对于更复杂的网页结构,可以将每个部分的文本提取到不同的对象中,以便于管理和维护。
(3)注意事项
  • 确保在国际化过程中考虑到文化差异,例如日期格式、数字格式等。
  • 如果需要支持更多语言,可以根据需要扩展 resources ****对象。
  • i18next ****还支持插件,可以实现更多功能,比如语言检测、后端加载等。

二、完整代码演示

html 复制代码
<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>国际化示例</title>
    <script src="https://unpkg.com/i18next@21.6.3/i18next.min.js"></script>
</head>
<body>
    <h1 id="title"></h1>
    <p id="description"></p>
    <button id="change-lang-en">切换到英文</button>
    <button id="change-lang-zh">切换到中文</button>

    <script>
        // 初始化 i18next
        i18next.init({
            lng: 'zh', // 默认语言
            resources: {
                en: {
                    translation: {
                        "title": "Welcome to Our Website",
                        "description": "This is a sample description in English."
                    }
                },
                zh: {
                    translation: {
                        "title": "欢迎来到我们的网站",
                        "description": "这是一个中文的示例描述。"
                    }
                }
            }
        }, function(err, t) {
            // 更新页面内容
            updateContent();
        });

        // 更新页面内容的函数
        function updateContent() {
            document.getElementById('title').innerHTML = i18next.t('title');
            document.getElementById('description').innerHTML = i18next.t('description');
        }

        // 切换语言的事件处理
        document.getElementById('change-lang-en').addEventListener('click', function() {
            i18next.changeLanguage('en', function(err, t) {
                updateContent();
            });
        });

        document.getElementById('change-lang-zh').addEventListener('click', function() {
            i18next.changeLanguage('zh', function(err, t) {
                updateContent();
            });
        });
    </script>
</body>
</html>

测试结果:


🙏至此,非常感谢阅读🙏

相关推荐
喝拿铁写前端11 小时前
AI 驱动前端开发覆盖的能力全景拆解
前端·javascript·人工智能
1024小神11 小时前
确认了,Cloudflare的R2对象存储S3接口api不支持在web端使用
前端
不染尘.11 小时前
应用层之WWW
服务器·javascript·css·网络·网络协议·计算机网络·html
KLW7511 小时前
vue v-for 列表渲染指令注意
前端·javascript·vue.js
zhengxianyi51511 小时前
vue 首屏加载优化
前端·javascript·vue.js·nginx·gzip·expires·静态文件缓存
John_ToDebug12 小时前
从 window.external 到 Mojo深度解析 Chromium 中 JS 与 C++ 的 7 种通信机制
javascript·chrome·mojo
老前端的功夫12 小时前
TypeScript 类型守卫:从编译原理到高级模式
前端·javascript·架构·typescript
未来之窗软件服务12 小时前
幽冥大陆(七十二) 东方仙盟-在线IP归属地自己封装—东方仙盟练气期
前端·javascript·tcp/ip·仙盟创梦ide·东方仙盟·阿雪技术观
QT 小鲜肉12 小时前
【Linux命令大全】001.文件管理之mc命令(实操篇)
linux·运维·服务器·前端·笔记
ttod_qzstudio12 小时前
备忘录之事件监听器绑定陷阱:为什么 .bind(this) 会移除失败?
javascript·typescript·内存泄漏·事件监听