自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Vue3 中如何做高性能的拼音搜索,提高用戶體驗(yàn)?

開發(fā) 前端
根據(jù)觀察,我發(fā)現(xiàn)我這個(gè)頁面的十幾個(gè)下拉框其實(shí)都有很多下拉項(xiàng)是相同的,這意味著,有一些項(xiàng)存在重復(fù)翻譯的問題。就比如這個(gè)“放米”,options1翻譯過一遍了,options2還翻譯一遍,這就導(dǎo)致了性能損耗。

下拉框搜索

最近頁面中需要一個(gè)下拉框,并且支持搜索功能(搜索選項(xiàng)文本和拼音),這是一個(gè)挺普通的小功能,代碼如下:

request.ts 先準(zhǔn)備一些假的下拉框數(shù)據(jù),并模擬請求:

圖片圖片

Index.vue 中進(jìn)行請求,并渲染下拉框,配置一些屬性,支持搜索選項(xiàng)文本:

圖片圖片

可以看到實(shí)現(xiàn)了搜索文本,但是產(chǎn)品說還得支持搜索拼音呢~可以看到當(dāng)前是不支持搜索拼音的。

圖片圖片

拼音搜索

拼音搜索其實(shí)也不難,用一些庫即可,比如 pinyin-pro。

pnpm i pinyin-pro

我可以使用 pinyin-pro 這個(gè)庫,在獲取數(shù)據(jù)的時(shí)候?yàn)槊恳豁?xiàng)的文本進(jìn)行拼音翻譯,并放到字段 keywords 中。

圖片圖片

現(xiàn)在可以看到每一項(xiàng)都有一個(gè) keywords 字段,里面存了每一項(xiàng)的文本和拼音。

圖片圖片

接著,在頁面中配置一下 Select 的搜索過濾函數(shù)。

圖片圖片

現(xiàn)在就支持了文本搜索和拼音搜索了。

圖片圖片

多個(gè)下拉框拼音搜索

上面例子是只有一個(gè),那如果有多個(gè)下拉框呢?比如有兩個(gè)下拉框,我準(zhǔn)備了兩個(gè)下拉框的假數(shù)據(jù)。

圖片圖片

接著在頁面中展示兩個(gè)下拉框:

圖片圖片

可以看到兩個(gè)下拉框的拼音數(shù)據(jù)耗時(shí)情況,其實(shí)當(dāng)時(shí)頁面上不止兩個(gè)下拉框,大概有十幾個(gè)下拉框,且數(shù)據(jù)都很巨大,如果每一個(gè)下拉框都要接近200ms的耗時(shí)的話,那用戶體驗(yàn)會很不好。

圖片圖片

性能優(yōu)化

根據(jù)觀察,我發(fā)現(xiàn)我這個(gè)頁面的十幾個(gè)下拉框其實(shí)都有很多下拉項(xiàng)是相同的,這意味著,有一些項(xiàng)存在重復(fù)翻譯的問題。

就比如這個(gè)“放米”,options1翻譯過一遍了,options2還翻譯一遍,這就導(dǎo)致了性能損耗。

圖片圖片

所以其實(shí)可以使用緩存來進(jìn)行優(yōu)化,思路就是:

1、準(zhǔn)備一個(gè)對象,key 是文本,value 是拼音

2、每次翻譯的時(shí)候

先檢測對象里是否能匹配到。

能匹配到直接用,不能匹配到才調(diào)用 pinyin-pro 進(jìn)行翻譯。

圖片圖片

這樣的話,能避免文本的重復(fù)翻譯,從而提升性能,由于 options2 有很多跟 options1 相同的項(xiàng),所以 options2 很多項(xiàng)的翻譯都是直接取緩存的,數(shù)據(jù)處理的速度大大提升!

圖片圖片

其實(shí)這種方式也是有局限性的,如果每一個(gè) options 的數(shù)據(jù)重合度都不高的話,那么這種優(yōu)化方式也就沒啥意義了

所以最好的方式還是叫后端翻譯好拼音,傳給前端。

類似的場景

其實(shí)不止是上面舉的例子,還有其他項(xiàng)目中類似的場景,需要用到這種優(yōu)化方式,比如:復(fù)雜的翻譯、復(fù)雜的數(shù)據(jù)處理。

例子終究是例子,重要的是能舉一反三。

責(zé)任編輯:武曉燕 來源: 前端之神
相關(guān)推薦

2021-05-18 07:51:37

Suspense組件Vue3

2022-08-03 09:11:31

React性能優(yōu)化

2022-07-20 11:13:05

前端JSONVue3

2023-11-28 09:03:59

Vue.jsJavaScript

2024-06-20 12:17:17

前端Vue3

2023-01-18 23:52:07

RTA用戶粒度運(yùn)營

2012-01-11 15:15:59

用戶體驗(yàn)高性能

2020-12-22 10:22:12

QQ運(yùn)動騰訊用戶

2021-12-02 05:50:35

Vue3 插件Vue應(yīng)用

2012-05-07 08:49:57

Clojure

2013-04-22 10:34:46

用戶體驗(yàn)設(shè)計(jì)UED認(rèn)知負(fù)荷

2021-12-08 09:09:33

Vue 3 Computed Vue2

2021-09-18 15:40:03

Vue單元測試命令

2021-12-01 08:11:44

Vue3 插件Vue應(yīng)用

2025-03-31 01:55:00

2016-09-01 09:39:20

攜程無線

2019-09-19 16:59:04

數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì)數(shù)據(jù)庫

2021-11-30 08:19:43

Vue3 插件Vue應(yīng)用

2024-11-06 10:16:22

2015-11-16 10:21:28

Java中鎖性能
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號