”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 带 API 的简单语言翻译器

带 API 的简单语言翻译器

发布于2024-10-31
浏览:122

Simple Language Translator with API

#100daysofMiva 编码挑战的第 8 天,我研究了一个简单的翻译模型,可以将一种语言翻译成另一种语言?
这是JS,这很神奇✨?

?语言翻译器脚本文档

概述

此 JavaScript 代码旨在创建一个有趣的交互式语言翻译器!它利用 MyMemory API 在不同语言之间翻译文本,并允许您交换语言、复制翻译,甚至大声朗读文本。 ??


特征

  • ?语言选择:用户可以从多种语言中进行选择,从阿姆哈拉语到祖鲁语!
  • ?语言交换: 单击按钮即可轻松在源语言和目标语言之间交换。
  • ?文本转语音: 聆听所选语言的原始文本或翻译文本。
  • ?复制到剪贴板: 单击即可复制原始文本或翻译文本。

代码分解

语言数据

const countries = { /*...*/ } 

该对象包含可用的语言及其各自的国家代码。例如,“en-GB”:“English”将语言代码与其名称配对。

动态下拉菜单

selectTag.forEach((tag, id) => {
    /*...*/
});

此代码使用国家对象中列出的所有语言动态填充下拉菜单。第一个下拉列表默认为英语(“en-GB”),第二个下拉列表默认为印地语(“hi-IN”)。

语言交换

exchageIcon.addEventListener("click", () => {
    /*...*/
});

单击交换图标允许用户在“从”和“到”字段之间交换文本和所选语言。

实时翻译

translateBtn.addEventListener("click", () => {
    /*...*/
});

单击“翻译”按钮时,文本将发送到 MyMemory API,翻译后的文本将显示在“目标文本”字段中。在等待响应时,会显示“正在翻译...”占位符。

文本转语音和复制

icons.forEach(icon => {
    /*...*/
});

本部分处理文本转语音和复制功能:

  • 语音:以所选语言大声播放文本。
  • 复制:将文本复制到剪贴板。

它是如何运作的

  1. 选择语言 ?:从下拉列表中选择您的语言。
  2. 输入或粘贴文本 ✍️:输入要翻译的文本。
  3. 翻译 ?:点击“翻译”按钮,观看奇迹发生!
  4. 交换、聆听或复制 ???:交换语言、聆听翻译或将文本复制到剪贴板。

依赖关系

  • MyMemory API:翻译功能由 MyMemory API 提供支持。确保您有有效的互联网连接才能正常工作。

潜在的增强功能

  • 语言自动检测:自动检测输入文本的语言。
  • 高级错误处理:改进对翻译错误或 API 故障的响应。
  • 多种翻译:显示可用的替代翻译。

以下是代码的工作原理及其用途的逐步细分:

第 1 步:定义可用语言

const countries = { /*...*/ }
  • 它的作用:该对象包含键值对,其中键是语言国家代码(例如英语的“en-GB”),值是语言的名称(例如“English” ).
  • 目的:此数据用于填充语言选择下拉列表,以便用户可以选择其源语言和目标语言。

第 2 步:选择 DOM 元素

const fromText = document.querySelector(".from-text"),
      toText = document.querySelector(".to-text"),
      exchageIcon = document.querySelector(".exchange"),
      selectTag = document.querySelectorAll("select"),
      icons = document.querySelectorAll(".row i");
      translateBtn = document.querySelector("button"),
  • 它的作用:此代码从 HTML 文档中选择各种元素并将它们存储在变量中以便以后轻松访问。
    • fromText 和 toText:用户输入文本并查看翻译的文本区域。
    • exchageIcon: 用于交换语言和文本的图标。
    • selectTag:用于选择语言的下拉菜单。
    • 图标:复制和语音功能的图标。
    • translateBtn: 触发翻译的按钮。

第 3 步:填充语言下拉列表

selectTag.forEach((tag, id) => {
    for (let country_code in countries) {
        let selected = id == 0 ? country_code == "en-GB" ? "selected" : "" : country_code == "hi-IN" ? "selected" : "";
        let option = ``;
        tag.insertAdjacentHTML("beforeend", option);
    }
});
  • 它的作用:此循环遍历国家对象并将每种语言添加为语言选择下拉列表中的选项。
    • 如果下拉菜单是第一个(id == 0),则默认选择英语(“en-GB”)。
    • 如果下拉菜单是第二个(id == 1),则默认选择印地语(“hi-IN”)。

第 4 步:交换语言和文本

exchageIcon.addEventListener("click", () => {
    let tempText = fromText.value,
        tempLang = selectTag[0].value;
    fromText.value = toText.value;
    toText.value = tempText;
    selectTag[0].value = selectTag[1].value;
    selectTag[1].value = tempLang;
});
  • 它的作用:单击交换图标时,此功能会在“从”和“到”文本区域以及所选语言之间交换文本。
    • tempText 暂时保存“from-text”字段中的原始文本。
    • tempLang 暂时保留第一个下拉列表中的原始语言。
    • 然后将“源文本”替换为“目标文本”,反之亦然。所选语言也会交换。

第5步:清除翻译文本

fromText.addEventListener("keyup", () => {
    if(!fromText.value) {
        toText.value = "";
    }
});
  • 它的作用:如果用户删除“from-text”字段中的所有文本,此函数也会自动清除“to-text”字段。
  • 目的:确保如果输入文本被清除,翻译也被清除,防止混淆。

第 6 步:翻译文本

translateBtn.addEventListener("click", () => {
    let text = fromText.value.trim(),
        translateFrom = selectTag[0].value,
        translateTo = selectTag[1].value;
    if(!text) return;
    toText.setAttribute("placeholder", "Translating...");
    let apiUrl = `https://api.mymemory.translated.net/get?q=${text}&langpair=${translateFrom}|${translateTo}`;
    fetch(apiUrl).then(res => res.json()).then(data => {
        toText.value = data.responseData.translatedText;
        data.matches.forEach(data => {
            if(data.id === 0) {
                toText.value = data.translation;
            }
        });
        toText.setAttribute("placeholder", "Translation");
    });
});
  • 它的作用:当单击“翻译”按钮时,此功能:
    1. 从“from-text”字段中提取文本
    2. 从下拉列表中标识所选语言
    3. 使用文本和所选语言向 MyMemory API 发送请求
    4. 从 API 接收翻译并将其显示在“目标文本”字段中。
    5. 更新占位符文本,同时等待翻译以指示该过程正在进行。

概括

该脚本允许用户通过动态和交互式界面在不同语言之间翻译文本。用户可以选择语言、输入文本、单击翻译、交换语言和文本、大声朗读翻译或将其复制到剪贴板。

享受不同语言的乐趣,让您的翻译之旅充满乐趣和互动! ??到下一个?✌?✨

在这里查看
https://app.marvelly.com.ng/100daysofMiva/day-8/

源代码
https://github.com/Marvellye/100daysofMiva/blob/main/Projects/Day_8-Simple_language_translator

版本声明 本文转载于:https://dev.to/marvellye/simple-language-translator-with-api-3bd7?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • VLONE Clothing:重新定义都市时尚的街头服饰品牌
    VLONE Clothing:重新定义都市时尚的街头服饰品牌
    VLONE 是少数几个在快速变化的市场中取得超越街头服饰行业所能想象的成就的品牌之一。 VLONE 由 A$AP Mob 集体的电影制片人之一 A$AP Bari 创立,现已发展成为一个小众项目,有时甚至成为都市时尚界的国际知名品牌。 VLONE 凭借大胆的图案、深厚的文化联系和限量版发售,在时尚界...
    编程 发布于2024-11-07
  • 如何使用PDO查询单行中的单列?
    如何使用PDO查询单行中的单列?
    使用 PDO 查询单行中的单列处理针对单行中特定列的 SQL 查询时,通常需要检索直接取值,无需循环。要使用 PDO 完成此操作,fetchColumn() 方法就派上用场了。fetchColumn() 的语法为:$col_value = $stmt->fetchColumn([column_...
    编程 发布于2024-11-07
  • 我是如何构建 PeerSplit:一款免费的点对点费用分摊应用程序 — 从构思到发布仅需数周时间
    我是如何构建 PeerSplit:一款免费的点对点费用分摊应用程序 — 从构思到发布仅需数周时间
    我构建了 PeerSplit——一个免费的、点对点的 Splitwise 替代品——从想法到发布仅用了两周时间! PeerSplit 是一款本地优先的应用程序,用于分配团体费用。它可以离线工作,100% 免费且私密,不需要注册或任何个人数据。 以下是我如何构建它以及我在此过程中学到的一切。 ...
    编程 发布于2024-11-07
  • 如何在 PHP 中解析子域名的根域名?
    如何在 PHP 中解析子域名的根域名?
    在 PHP 中从子域解析域名在 PHP 中,从子域中提取根域名是一项常见任务。当您需要识别与子域关联的主网站时,这非常有用。为了实现这一目标,让我们探索一个解决方案。提供的代码片段利用 parse_url 函数将 URL 分解为其组件,包括域名。随后,它使用正则表达式来隔离根域,而忽略子域。以下示例...
    编程 发布于2024-11-07
  • 使用 Socket.io 构建实时应用程序
    使用 Socket.io 构建实时应用程序
    介绍 Socket.io 是一个 JavaScript 库,允许 Web 客户端和服务器之间进行实时通信。它支持创建交互式动态应用程序,例如聊天室、多人游戏和直播。凭借其易于使用的 API 和跨平台兼容性,Socket.io 已成为构建实时应用程序的流行选择。在本文中,我们将探讨 ...
    编程 发布于2024-11-07
  • 重写 `hashCode()` 和 `equals()` 如何影响 HashMap 性能?
    重写 `hashCode()` 和 `equals()` 如何影响 HashMap 性能?
    了解 equals 和 hashCode 在 HashMap 中的工作原理Java 中的 HashMap 使用 hashCode() 和 equals() 方法的组合来有效地存储和检索键值对。当添加新的键值对时,首先计算键的hashCode()方法,以确定该条目将被放置在哪个哈希桶中。然后使用 eq...
    编程 发布于2024-11-07
  • 使用 Google Apps 脚本和 Leaflet.js 构建交互式 XY 图像图
    使用 Google Apps 脚本和 Leaflet.js 构建交互式 XY 图像图
    Google Maps has a ton of features for plotting points on a map, but what if you want to plot points on an image? These XY Image Plot maps are commonly...
    编程 发布于2024-11-07
  • 理解 React 中的状态变量:原因和方法
    理解 React 中的状态变量:原因和方法
    在深入研究状态变量之前,让我们先来分析一下 React 组件的工作原理! 什么是 React 组件? 在 React 中,组件是一段可重用的代码,代表用户界面 (UI) 的一部分。它可以像 HTML 按钮一样简单,也可以像完整的页面一样复杂。 React 中的状态...
    编程 发布于2024-11-07
  • Miva 的日子:第 4 天
    Miva 的日子:第 4 天
    这是 100 天 Miva 编码挑战的第四天。我跳过了第三天的报告,因为我被困在我的网页设计项目中,需要改变节奏。这就是为什么我今天决定深入研究 JavaScript。 JavaScript JavaScript 就像系统和网站的行为组件。它为网站增加了交互性和响应能力,使其成为网页设计和开发的关...
    编程 发布于2024-11-07
  • TailGrids React:+ Tailwind CSS React UI 组件
    TailGrids React:+ Tailwind CSS React UI 组件
    我们很高兴推出 TailGrids React,这是您的新首选工具包,可用于轻松构建令人惊叹的响应式 Web 界面。 TailGrids React 提供了超过 600 免费和高级 React UI 组件、块、部分和模板的大量集合 - 所有这些都是用 Tailwind CSS 精心制作的。 无论您...
    编程 发布于2024-11-07
  • 如何用列表值反转字典?
    如何用列表值反转字典?
    使用列表值反转字典:解决方案在本文中,我们探讨了使用列表值反转字典的挑战。给定一个索引字典,其中键是文件名,值是这些文件中出现的单词列表,我们的目标是创建一个倒排字典,其中单词是键,值是文件名列表。提供的反转函数 invert_dict,不适用于以列表值作为键的字典,因为它会失败并显示“TypeEr...
    编程 发布于2024-11-07
  • 现代 Web 开发框架:比较流行的框架及其用例
    现代 Web 开发框架:比较流行的框架及其用例
    在快速发展的 Web 开发领域,选择正确的框架可以显着影响项目的成功。本文深入研究了一些最流行的 Web 开发框架,比较了它们的优势和理想用例,以帮助开发人员做出明智的决策。 反应 概述 React 由 Facebook 开发和维护,是一个用于构建用户界面的 Java...
    编程 发布于2024-11-07
  • 如何在 Go 1.18 中安全地使用泛型类型解组 JSON?
    如何在 Go 1.18 中安全地使用泛型类型解组 JSON?
    Unmarshal 中的泛型使用 (Go 1.18)在 Go 1.18 中使用泛型时,例如创建一个容器来保存各种报告类型,可能会出现类型限制。考虑以下设置:由结构表示的多种报告类型具有通用类型参数的 ReportContainer 包装器可报告,约束为实现可报告接口鉴别器ReportType 在解组...
    编程 发布于2024-11-07
  • 了解 Effect-TS 中的选项排序
    了解 Effect-TS 中的选项排序
    示例 1:使用 O.andThen 忽略第一个值 概念 O.andThen 函数允许您执行两个选项的序列,其中结果仅由第二个选项决定。当第一个选项达到目的,但后续操作中不需要它的值时,这很有用。 代码 function sequencing_ex01...
    编程 发布于2024-11-07
  • React 初学者指南:基础知识入门
    React 初学者指南:基础知识入门
    React 已成为现代 Web 开发的基石,以其高效、灵活性和强大的生态系统而闻名。 React 由 Facebook 开发,允许开发人员创建可重用的 UI 组件,从而简化了构建交互式用户界面的过程。 无论您是想构建复杂的单页应用程序还是只是想提高您的 Web 开发技能,掌握 React 都是一笔...
    编程 发布于2024-11-07

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3