news 2026/4/23 14:28:52

前端中文汉字转拼音

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
前端中文汉字转拼音

本文简介

点赞 + 关注 + 收藏 = 学会了


这次要推荐一个在前端就能实现汉字转拼音的工具库 ——pinyin-pro

这个库不止能把中文转成拼音输出,还有拼音匹配、获取声母、获取韵母、获取拼音首字母等功能。

而且还是中文文档啦这不是废话吗?


先看看效果~



pinyin-pro

pinyin-pro包含了和拼音相关的大部分转换功能。

官方文档也写得很好,案例也很全。这里我就不在重复官方文档上面的案例了。

但有时候可能打开github有点困难,所以本文把官方文档的参数部分搬过来。


特色功能

  • 获取汉字、词语、句子等多种格式的拼音
  • 获取声母
  • 获取韵母
  • 获取拼音首字母
  • 获取音调
  • 获取多音字的多种拼音
  • 支持人名姓氏模式
  • 支持自定义拼音
  • 支持字符串和数组两种输出形式
  • 支持拼音文本匹配功能

安装

npm install pinyin-pro # 或 yarn add pinyin-pro

引入

浏览器script引入:

<!-- 引入某个版本,如3.5.0版本 --> <script src="https://cdn.jsdelivr.net/gh/zh-lx/pinyin-pro@3.5.0/dist/pinyin-pro.js"></script> <!-- 或 --> <!-- 引入最新版本 --> <script src="https://cdn.jsdelivr.net/gh/zh-lx/pinyin-pro@latest/dist/pinyin-pro.js"></script> <script> var { pinyin } = pinyinPro; pinyin('汉语拼音'); // 'hàn yǔ pīn yīn' </script>

ESModule浏览器引入:

import { pinyin } from 'pinyin-pro' pinyin('汉语拼音') // 'hàn yǔ pīn yīn'

commonjs node引入:

const { pinyin } = require('pinyin-pro') pinyin('汉语拼音') // 'hàn yǔ pīn yīn'

动态导入:

import('pinyin-pro').then((exports) => { exports.pinyin('汉语拼音') // 'hàn yǔ pīn yīn' })

参数

pinyin(word, options)接收两个参数

  • **word:**必填。String 类型,需要转化为拼音的中文
  • **options:**可选。Object 类型,用于配置各种输出形式,options 的键值配置如下:
参数说明类型可选值默认值
pattern输出的结果的信息(拼音 / 声母 / 韵母 / 音调 / 首字母)stringpinyin / initial / final / num / firstpinyin
toneType音调输出形式(拼音符号 / 数字 / 不加音调)stringsymbol / num / nonesymbol
type输出结果类型(字符串/数组)stringstring / arraystring
multiple输出多音字全部拼音(仅在 word 为长度为 1 的汉字字符串时生效)booleantrue / falsefalse
mode拼音查找的模式(常规模式 / 姓氏模式)stringnormal / surnamenormal
removeNonZh是否输入字符串中将非汉字的字符过滤掉booleantrue / falsefalse
nonZh定义非汉字字符的输出形式stringspaced / consecutive / removedspaced
v是否将拼音 ü 替换为 vbooleantrue / falsefalse

以上就是pinyin-pro的安装、引入和参数,更多使用案例可以查看官方文档。



实时输出拼音

简单介绍完pinyin-pro后,我还想介绍几个HTML标签:<ruby><rp><rt>

<ruby>标签可以做注释,很适合给汉字做注音。

<ruby>元素由一个或多个需要解释/发音的字符和一个提供该信息的<rt>元素组成,还包括可选的<rp>元素,定义当浏览器不支持 “ruby” 元素时显示的内容。


在支持ruby的浏览器是这样显示的:

<ruby>雷猴<rp>(</rp><rt>leihou</rt><rp>)</rp></ruby>

不支持ruby的浏览器的显示效果:


需要注意的是,注解要写在正文内容后面。



了解了pinyin-pro<ruby>的用法,我们尝试一下完成文章开头的那个效果。

<p><ruby><spanid="text"></span><rp>(</rp><rtid="phoneticize"></rt><rp>)</rp></ruby></p><inputtype="text"id="inp"oninput="transition(this)"><scriptsrc="https://cdn.jsdelivr.net/gh/zh-lx/pinyin-pro@latest/dist/pinyin-pro.js"></script><script>const{pinyin}=pinyinProconsttext=document.getElementById('text')constphoneticize=document.getElementById('phoneticize')// 防抖处理lettimer=nullfunctiontransition(e){timer&&clearTimeout(timer)// 防抖处理timer=setTimeout(function(){letres=pinyin(e.value)// 汉字转拼音text.innerText=e.value// 在页面上展示输入的文本phoneticize.innerText=res// 在文本上面展示拼音},200)}</script>

把代码放到本地运行一下吧~

前端用pinyin-pro能高效实现汉字转拼音等功能,落地时要考虑组件复用、快速部署的工程效率问题。试试RollCode 低代码平台,轻松搞定私有化部署、自定义组件、静态页面发布(SSG + SEO)需求。


点赞 + 关注 + 收藏 = 学会了

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/20 9:28:14

Annotorious入门教程:图片注释工具

本文简介 最近有工友问我前端怎么给图片做标注。使用 Fabric.js 或者 Konva.js 等库确实可以实现&#xff0c;但我又好奇有没有专门做图片标注的工具呢&#xff1f; 在网上搜了一下发现 Annotorious 可以实现这个功能。Annotorious 提供了图片注释和标注功能&#xff0c;而且…

作者头像 李华
网站建设 2026/4/23 13:04:03

CNN结构新解:从经典到前沿,一文掌握核心演进与实战趋势

CNN结构新解&#xff1a;从经典到前沿&#xff0c;一文掌握核心演进与实战趋势 引言 近年来&#xff0c;卷积神经网络&#xff08;CNN&#xff09;并未因Transformer的崛起而黯然失色&#xff0c;反而通过融合创新与工程优化&#xff0c;在计算机视觉领域持续焕发新生。从引入…

作者头像 李华
网站建设 2026/4/23 13:01:40

我的 Trae Skill 实践|使用 UV 工具一键搭建 Python 项目开发环境

【个人主页&#xff1a;玄同765】 大语言模型&#xff08;LLM&#xff09;开发工程师&#xff5c;中国传媒大学数字媒体技术&#xff08;智能交互与游戏设计&#xff09; 深耕领域&#xff1a;大语言模型开发 / RAG知识库 / AI Agent落地 / 模型微调 技术栈&#xff1a;Python …

作者头像 李华
网站建设 2026/4/22 19:56:40

(9-2-03)电源管理与能源系统:能耗分析与功率管理(3)基于分布式神经网络架构的人形机器人算力分配

9.2.4 基于分布式神经网络架构的人形机器人算力分配基于分布式神经网络架构的人形机器人算力分配&#xff0c;核心是通过“模块化硬件部署分布式计算节点实时通信总线”&#xff0c;打破传统集中式算力架构的瓶颈&#xff0c;实现算力与任务需求的精准匹配&#xff0c;其技术范…

作者头像 李华
网站建设 2026/4/23 9:49:34

懒加载单例模式中DCL方式和原理解析

一、DCL 是什么&#xff1f; DCL&#xff08;Double Check Lock&#xff0c;双重检查锁&#xff09;是 Java 中懒加载单例模式的高性能实现方案&#xff0c;核心思路是&#xff1a; 第一次检查&#xff1a;无锁判断实例是否已初始化&#xff0c;避免每次调用都加锁&#xff08…

作者头像 李华
网站建设 2026/4/23 9:48:47

提供一下获取的NTP时间中的月和周的枚举

你这个 CIPSNTPTIME 返回的时间字符串格式本质上就是 ctime() 风格&#xff08;例如&#xff1a;Wed Feb 4 10:14:03 2026&#xff09;&#xff0c;其中&#xff1a;周&#xff1a;固定是 3 字母英文缩写月&#xff1a;固定是 3 字母英文缩写下面把“周 / 月”的枚举&#xff0…

作者头像 李华