js實現(xiàn)中文轉(zhuǎn)拼音的完整步驟記錄
使用js搞了一個中文轉(zhuǎn)拼音的包,倉庫地址可見:pinyin-pro
特色功能
- 支持漢字、詞語、句子多種格式輸入獲取
- 獲取拼音
- 獲取聲母
- 獲取韻母
- 獲取拼音首字母
- 獲取音調(diào)
- 獲取多音字的多種拼音
- 支持字符串和數(shù)組兩種輸出形式
安裝
npm 安裝
npm install pinyin-pro
yarn 安裝
yarn add pinyin-pro
引入
瀏覽器 script 引入:
<!--引入某個版本,如3.2.0版本-->
<!-- <script src="https://cdn.jsdelivr.net/gh/zh-lx/pinyin-pro@3.2.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 引入:
const { pinyin } = require('pinyin-pro');
pinyin('漢語拼音'); // 'hàn yǔ pīn yīn'
參數(shù)
pinyin(word, options) 接收兩個參數(shù)
word:必填。String 類型,需要轉(zhuǎn)化為拼音的中文
options:可選。Object 類型,用于配置各種輸出形式,options 的鍵值配置如下:
| 參數(shù) | 說明 | 類型 | 可選值 | 默認值 |
|---|---|---|---|---|
| pattern | 輸出的結(jié)果的信息(拼音 / 聲母 / 韻母 / 音調(diào) / 首字母) | string | pinyin / initial / final / num / first | pinyin |
| toneType | 音調(diào)輸出形式(拼音符號 / 數(shù)字 / 不加音調(diào)) | string | symbol / num / none | symbol |
| type | 輸出結(jié)果類型(字符串/數(shù)組) | string | string / array | string |
| multiple | 輸出多音字全部拼音(僅在 word 為長度為 1 的漢字字符串時生效) | boolean | true / false | false |
使用示例
獲取拼音
import { pinyin } from 'pinyin-pro';
// 獲取帶音調(diào)拼音
pinyin('漢語拼音'); // 'hàn yǔ pīn yīn'
// 獲取不帶聲調(diào)的拼音
pinyin('漢語拼音', { toneType: 'none' }); // 'han yu pin yin'
// 獲取聲調(diào)轉(zhuǎn)換為數(shù)字后綴的拼音
pinyin('漢語拼音', { toneType: 'num' }); // 'han4 yu3 pin1 yin1'
// 獲取數(shù)組形式帶音調(diào)拼音
pinyin('漢語拼音', { type: 'array' }); // ["hàn", "yǔ", "pīn", "yīn"]
// 獲取數(shù)組形式不帶聲調(diào)的拼音
pinyin('漢語拼音', { toneType: 'none', type: 'array' }); // ["han", "yu", "pin", "yin"]
// 獲取數(shù)組形式聲調(diào)轉(zhuǎn)換為數(shù)字后綴的拼音
pinyin('漢語拼音', { toneType: 'num', type: 'array' }); // ["han4", "yu3", "pin1", "yin1"]
獲取聲母
import { pinyin } from 'pinyin-pro';
// 獲取聲母
pinyin('漢語拼音', { pattern: 'initial' }); // 'h y p y'
// 獲取數(shù)組形式聲母
pinyin('漢語拼音', { pattern: 'initial', type: 'array' }); // ["h", "y", "p", "y"]
獲取韻母
import { pinyin } from 'pinyin-pro';
// 獲取帶音調(diào)韻母
pinyin('漢語拼音', { pattern: 'final' }); // 'àn ǔ īn īn'
// 獲取不帶音調(diào)韻母
pinyin('漢語拼音', { pattern: 'final', toneType: 'none' }); // 'an u in in'
// 獲取音調(diào)為數(shù)字的韻母
pinyin('漢語拼音', { pattern: 'final', toneType: 'num' }); // 'an4 u3 in1 in1'
// 獲取數(shù)組形式帶音調(diào)韻母
pinyin('漢語拼音', { pattern: 'final', type: 'array' }); // ["àn", "ǔ", "īn", "īn"]
// 獲取數(shù)組形式不帶音調(diào)韻母
pinyin('漢語拼音', { pattern: 'final', toneType: 'none', type: 'array' }); // ["an", "u", "in", "in"]
// 獲取數(shù)組形式音調(diào)為數(shù)字的韻母
pinyin('漢語拼音', { pattern: 'final', toneType: 'num', type: 'array' }); // ['an4', 'u3', 'in1', 'in1']
獲取音調(diào)
import { pinyin } from 'pinyin-pro';
// 獲取音調(diào)
pinyin('漢語拼音', { pattern: 'num' }); // '4 3 1 1'
// 獲取數(shù)組形式音調(diào)
pinyin('漢語拼音', { pattern: 'num', type: 'array' }); // ["4", "3", "1", "1"]
獲取拼音首字母
import { pinyin } from 'pinyin-pro';
// 獲取拼音首字母
pinyin('趙錢孫李額', { pattern: 'first' }); // 'z q s l é'
// 獲取不帶音調(diào)拼音首字母
pinyin('趙錢孫李額', { pattern: 'first', toneType: 'none' }); // 'z q s l e'
// 獲取數(shù)組形式拼音首字母
pinyin('趙錢孫李額', { pattern: 'first', type: 'array' }); // ['z', 'q', 's', 'l', 'é']
// 獲取數(shù)組形式不帶音調(diào)拼音首字母
pinyin('趙錢孫李額', { pattern: 'first', toneType: 'none', type: 'array' }); // ['z', 'q', 's', 'l', 'e']
獲取單個字的多音
只有單字可以獲取到多音模式, 詞語、句子無效。同樣可以通過配置 options 選項獲取數(shù)組形式、韻母等格式
import { pinyin } from 'pinyin-pro';
// 獲取多音
pinyin('好', { multiple: true }); // 'hǎo hào'
// 獲取數(shù)組形式多音
pinyin('好', { multiple: true, type: 'array' }); // ["hǎo", "hào"]
總結(jié)
到此這篇關(guān)于js實現(xiàn)中文轉(zhuǎn)拼音的文章就介紹到這了,更多相關(guān)js中文轉(zhuǎn)拼音內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
有一段有意思的代碼-javascript現(xiàn)實多行信息
有一段有意思的代碼-javascript現(xiàn)實多行信息...2007-08-08
讓網(wǎng)站自動生成章節(jié)目錄索引的多個js代碼
這篇文章主要介紹了讓博客園博客自動生成章節(jié)目錄索引的多個js代碼,需要的朋友可以參考下2018-01-01
JavaScript使用canvas實現(xiàn)錨點摳圖功能
在日常的圖片處理中,我們經(jīng)常會遇到需要摳圖的情況,無論是為了美化照片、制作海報,還是進行圖片合成,摳圖對于我們來說也是一種很常用的功能了,今天就讓我們一起來看下怎么使用canvas來實現(xiàn)一個錨點摳圖功能2024-03-03
Webpack打包過程中處理ES6模塊的循環(huán)依賴問題小結(jié)
Webpack通過“暫時性引用”特性處理ES6模塊的循環(huán)依賴,即在模塊加載時創(chuàng)建占位符,確保模塊能夠正確加載,本文介紹Webpack打包過程中如何處理ES6模塊的循環(huán)依賴,感興趣的朋友一起看看吧2025-02-02

