Vue——前端vue3項目使用漢字轉拼音

在 Vue3 項目中,可以通過以下 第三方 JavaScript 包 實現漢字轉拼音。這些包均兼容 Vue3,且無需依賴后端處理:


推薦方案

1. pinyin-pro
  • 特點:功能強大、支持多音字、聲調、拼音匹配、輕量級(~20KB)。
  • 安裝
    npm install pinyin-pro
    # 或
    yarn add pinyin-pro
    
  • 代碼示例
    <template><div>{{ pinyinResult }}</div>
    </template><script setup>
    import { pinyin } from 'pinyin-pro';const text = "你好世界";
    const pinyinResult = pinyin(text, { toneType: 'none' }); // 不帶聲調
    // 輸出: "ni hao shi jie"// 帶聲調
    // const withTone = pinyin(text, { toneType: 'symbol' }); // "nǐ hǎo shì jiè"
    </script>
    

2. pinyin
  • 特點:老牌庫、支持多音字(需手動處理)、自定義格式。
  • 安裝
    npm install pinyin
    
  • 代碼示例
    <script setup>
    import pinyin from 'pinyin';const text = "重慶火鍋";
    const result = pinyin(text, {style: pinyin.STYLE_NORMAL, // 不帶聲調heteronym: true // 啟用多音字模式
    });
    // 輸出: [ ['chong'], ['qing'], ['huo'], ['guo'] ]
    // 注意:多音字返回數組,需根據上下文選擇
    </script>
    

3. tiny-pinyin
  • 特點:超輕量(~2KB)、基礎轉換,不支持多音字
  • 安裝
    npm install tiny-pinyin
    
  • 代碼示例
    <script setup>
    import { pinyin } from 'tiny-pinyin';const text = "漢字轉拼音";
    if (pinyin.isSupported()) {const result = pinyin.convertToPinyin(text, '-', true); // 輸出: "han-zi-zhuan-pin-yin"
    }
    </script>
    

關鍵選擇建議

庫名多音字支持聲調體積適用場景
pinyin-pro??20KB復雜需求、多音字處理
pinyin?(需手動)?100KB需要高度自定義
tiny-pinyin??2KB輕量級、基礎轉換

注意事項

  1. 多音字問題

    • 如“重慶”中的“重”可能是 chongzhong,前端庫通常無法自動判斷,需結合業務邏輯或后端輔助。
    • pinyin-pro 提供 match 方法處理簡單多音詞:
      import { match } from 'pinyin-pro';
      match('行長', 'hang zhang'); // 返回匹配結果
      
  2. 性能優化

    • 處理長文本時,建議在 Web Worker 中運行拼音轉換,避免阻塞主線程。
  3. 國際化

    • 若需拼音首字母(如搜索建議),可直接截取拼音首字符:
      const initials = pinyin(text).map(p => p[0]).join('');
      // "你好" → "NH"
      

總結

  • 推薦 pinyin-pro:功能全面,適合大多數場景。
  • 若追求極簡,選擇 tiny-pinyin
  • 需要處理多音字但接受手動控制的場景,使用 pinyin

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/80249.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/80249.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/80249.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

批量統計PDF頁數,統計圖像屬性

軟件介紹&#xff1a; 1、支持批量統計PDF、doc\docx、xls\xlsx頁數 2、支持統計指定格式文件數量&#xff08;不填格式就是全部&#xff09; 3、支持統計JPG、JPEG、PNG圖像屬性 4、支持統計多頁TIF頁數、屬性 5、支持統計PDF、JPG畫幅 統計圖像屬性 「托馬斯的文件助手」…

LeetCode 每日一題 2025/5/5-2025/5/11

記錄了初步解題思路 以及本地實現代碼&#xff1b;并不一定為最優 也希望大家能一起探討 一起進步 目錄 5/5 790. 多米諾和托米諾平鋪5/6 1920. 基于排列構建數組5/7 3341. 到達最后一個房間的最少時間 I5/8 3342. 到達最后一個房間的最少時間 II5/9 3343. 統計平衡排列的數目5…

pytest自動化測試執行環境切換的兩種解決方案

&#x1f345; 點擊文末小卡片&#xff0c;免費獲取軟件測試全套資料&#xff0c;資料在手&#xff0c;漲薪更快 一、痛點分析 在實際企業的項目中&#xff0c;自動化測試的代碼往往需要在不同的環境中進行切換&#xff0c;比如多套測試環境、預上線環境、UAT環境、線上環…

visual studio 2015 安裝閃退問題

參考鏈接&#xff1a; VS2012安裝時啟動界面一閃而過問題解決辦法 visual studio 2015 安裝閃退問題

RocketMQ Kafka區別

架構 ZooKeeper&#xff1a;管理 Broker 注冊、分區 Leader 選舉及消費者組狀態。Broker&#xff1a;存儲 Partition數據&#xff0c;每個 Partition 為獨立日志文件。Producer/Consumer&#xff1a;通過 ZooKeeper獲取路由信息&#xff0c;實現消息分發與消費。 NameServer&am…

MySQL進階篇2_SQL優化、鎖

文章目錄 1 SQL優化1.1插入數據優化1.2主鍵優化頁分裂頁合并主鍵設計原則 1.3order by設計優化1.4group by設計優化小理解 1.5limit設計優化順序IO和隨機IO小疑惑 1.6count設計優化1.7update優化關于隱式事務事務的DML操作 鎖全局鎖表級鎖表鎖元數據鎖意向鎖 行級鎖鎖的釋放條件…

如何測試 esp-webrtc-solution_solutions_doorbell_demo 例程?

軟件準備 esp-webrtc-solution/solutions/doorbell_demo 例程 此例程集成了 WebSocket 傳輸視頻流的應用 硬件準備 ESP32P4-Function-Ev-Board 環境搭建 推薦基于 esp-idf v5.4.1 版本的環境來編譯此例程 若編譯時出現依賴的組件報錯&#xff0c;可進行如下修改&#xff…

TransmittableThreadLocal:穿透線程邊界的上下文傳遞藝術

文章目錄 前言一、如何線程上下文傳遞1.1 ThreadLocal單線程1.2 InheritableThreadLocal的繼承困境1.3 TTL的時空折疊術 二、TTL核心設計解析2.1 時空快照機制2.2 裝飾器模式2.3 采用自動清理機制 三、設計思想啟示四、實踐啟示錄結語 前言 在并發編程領域&#xff0c;線程上下…

【數據結構】——棧

一、棧的概念和結構 棧其實就是一種特殊的順序表&#xff0c;其只允許在一端進出&#xff0c;就是棧的數據的插入和刪除只能在一端進行&#xff0c;進行數據的插入和刪除操作的一端稱為棧頂&#xff0c;另一端稱為棧底。棧中的元素遵循先進后出LIFO&#xff08;Last InFirst O…

大數據技術全景解析:Spark、Hadoop、Hive與SQL的協作與實戰

引言&#xff1a;當數據成為新時代的“石油” 在數字經濟時代&#xff0c;數據量以每年50%的速度爆發式增長。如何高效存儲、處理和分析PB級數據&#xff0c;成為企業競爭力的核心命題。本文將通過通俗類比場景化拆解&#xff0c;帶你深入理解四大關鍵技術&#xff1a;Hadoop、…

Android13 權限管理機制整理

一、概述 權限機制作為Android 系統安全的保證,很重要,這里整理一下 權限機制中framework 部分,selinux等其他的Android權限機制不在本次討論范圍內 二、個版本差異分類 Android13 Android12 Android11 及以下 拋開版本差異權限機制分為兩大類 一類是之前apk在Android6.0…

MySQL的Order by與Group by優化詳解!

目錄 前言核心思想&#xff1a;讓索引幫你“排好序”或“分好組”Part 1: ORDER BY 優化詳解1.1 什么是 Filesort&#xff1f;為什么它慢&#xff1f;1.2 如何避免 Filesort&#xff1f;—— 利用索引的有序性1.3 EXPLAIN 示例 (ORDER BY) Part 2: GROUP BY 優化詳解2.1 什么是…

awesome-digital-human本地部署及配置:打造高情緒價值互動指南

在數字化交互的浪潮中&#xff0c;awesome-digital-human-live2d項目為我們打開了本地數字人互動的大門。結合 dify 聊天 api&#xff0c;并借鑒 coze 夸夸機器人的設計思路&#xff0c;能為用戶帶來充滿情緒價值的交互體驗。本文將詳細介紹其本地部署步驟、dify 配置方法及情緒…

[ctfshow web入門] web68

信息收集 highlight_file被禁用了&#xff0c;使用cinclude("php://filter/convert.base64-encode/resourceindex.php");讀取index.php&#xff0c;使用cinclude("php://filter/convert.iconv.utf8.utf16/resourceindex.php");可能有些亂碼&#xff0c;不…

計算機網絡:深度解析基于鏈路狀態的內部網關協議IS-IS

IS-IS(Intermediate System to Intermediate System)路由協議詳解 IS-IS(Intermediate System to Intermediate System)是一種基于鏈路狀態的內部網關協議(IGP),最初由ISO為OSI(開放系統互連)模型設計,后經擴展支持IP路由。它廣泛應用于大型運營商網絡、數據中心及復…

SEGGER項目

SystemView 查看版本, 查看SEGGER官網&#xff0c;release時間是2019-12-18日, 而3.12.0的版本日期是2020-05-04 #define SEGGER_SYSVIEW_MAJOR 3 #define SEGGER_SYSVIEW_MINOR 10 #define SEGGER_SYSVIEW_REV 0SEGGER EMBEDDED Studio 根據S…

Linux——Mysql索引和事務

目錄 一&#xff0c;Mysql索引介紹 1&#xff0c;索引概述 1&#xff0c;索引的優點 2&#xff0c;索引的缺點 2&#xff0c;索引作用 3&#xff0c;索引分類 普通索引 唯一索引 主鍵索引 組合索引 全文索引 4&#xff0c;查看索引 5&#xff0c;刪除索引 6&…

【Web】LACTF 2025 wp

目錄 arclbroth lucky-flag whack-a-mole arclbroth 看到username為admin能拿到flag 但不能重復注冊存在的用戶 這題是secure-sqlite這個庫的問題&#xff0c;底層用的是C&#xff0c;沒處理好\0字符截斷的問題 &#xff08;在 Node.js 中&#xff0c;由于其字符串表示方式…

訪問者模式(Visitor Pattern)詳解

文章目錄 1. 訪問者模式概述1.1 定義1.2 基本思想 2. 訪問者模式的結構3. 訪問者模式的UML類圖4. 訪問者模式的工作原理5. Java實現示例5.1 基本實現示例5.2 訪問者模式處理復雜對象層次結構5.3 訪問者模式在文件系統中的應用 6. 訪問者模式的優缺點6.1 優點6.2 缺點 7. 訪問者…

matlab介紹while函數

MATLAB 中的 while 語句介紹 在 MATLAB 中&#xff0c;while 語句是一種循環結構&#xff0c;用于在滿足特定條件時反復執行一段代碼塊。與 for 循環不同&#xff0c;while 循環的執行次數是動態的&#xff0c;取決于循環條件是否為真。 語法 while condition% 循環體代碼 e…