Vue3實現(xiàn)Emoji表情的四種方案
使用輸入法輸入表情
Textarea中支持接受輸入法輸入的表情,在 macOs 中直接輸入“微笑”,會直接打印出??的表情,和文字沒區(qū)別。
但是這種方案不好的點在于只能手輸,沒辦法達到選擇的效果。
使用Unicode編碼輸入表情
在 Unicode 編碼中存在對應表情的編碼區(qū)間,位于基本多語言面(Basic Multilingual Plane,BMP),碼點在 U+1F600 到 U+1F6FF。
因為目前使用的是 textarea 作為輸入框,所以 Unicode 編碼在輸入框顯示出來是純文本,這就導致用戶很有可能出現(xiàn)誤修改。
另外會話信息的展示區(qū)域,現(xiàn)在也是直接使用的模板語法,需要在展示區(qū)使用 v-html 才能正常展示表情,否則也是純文本。
但是基于 Unicode 編碼的這種模式非常輕量,并不需要額外的庫和特殊操作。
使用自定義內(nèi)容進行對應
使用自定義內(nèi)容進行對應,這應該是QQ的表情方案(雖然我沒看過源碼,純猜測)。
QQ的輸入框在使用 “/” 進行輸入的時候會彈出相應的表情提示,確定以后變成表情。這里面大概率是經(jīng)歷了對特定編碼的轉(zhuǎn)換。
同理我們也可以用這種方案進行轉(zhuǎn)換,可以使用特定的符號在系統(tǒng)中進行解析,生成表情。
比如系統(tǒng)中寫死 “[wx]” 代表是的 ?? ,當輸入框通過 input 事件監(jiān)聽到存在 “[wx]” 的時候,代碼將其自動轉(zhuǎn)換為 ??。
插個眼,后面把 Unicode 編碼通過這種方式實現(xiàn)一下。
使用 emoji-mart-vue 插件
使用插件是性價比最高的方案,這個插件相當于直接把輸入的emoji集成了,無需改造原本的代碼,插入的emoji表情輸入法輸入的沒有區(qū)別。
唯一可能存在的瑕疵可能是沒辦法自定義。
安裝
npm install emoji-mart-vue-fast
使用
<template>
<Picker :data="emojiIndex" :emojiSize="18" :showPreview="false" :infiniteScroll="false" :i18n="emojiI18n"
set="apple" @select="handlerEmoji" />
</template>
<script>
import data from 'emoji-mart-vue-fast/data/all.json';
import 'emoji-mart-vue-fast/css/emoji-mart.css'
import { Picker, EmojiIndex } from 'emoji-mart-vue-fast/src';
export default {
components: { Picker, EmojiIndex },
data() {
return {
editorValue: "",
emojiOpen: false,
emojiI18n: {
search: '搜索',
notfound: 'No Emoji Found',
categories: {
search: '搜索結(jié)果',
recent: '經(jīng)常使用',
smileys: '表情與情感',
people: '人物與身體',
nature: '動物與自然',
foods: '食物與飲料',
activity: '活動',
places: '旅行與地理',
objects: '物品',
symbols: '符號標志',
flags: '旗幟',
custom: 'Custom',
joy: '哭笑'
}
},
}
},
computed: {
emojiIndex() {
return new EmojiIndex(data);
}
},
methods: {
// 選中emoji方法
handlerEmoji(event) {
console.log(event);
},
}
}
</script>
結(jié)論
想要自定義可以嘗試第三種方案,現(xiàn)成的直接第四種方案。
到此這篇關于Vue3實現(xiàn)Emoji表情的四種方案的文章就介紹到這了,更多相關Vue3實現(xiàn)Emoji表情內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
VScode中配置ESlint+Prettier詳細步驟(附圖文介紹)
這篇文章主要介紹了VScode中配置ESlint+Prettier詳細步驟,文中通過代碼示例講解的非常詳細,對大家的學習或工作有一定的幫助,需要的朋友可以參考下2024-12-12
詳解vue數(shù)組遍歷方法forEach和map的原理解析和實際應用
這篇文章主要介紹了詳解vue數(shù)組遍歷方法forEach和map的原理解析和實際應用,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-11-11
vue如何使用element ui表格el-table-column在里面做判斷
這篇文章主要介紹了vue如何使用element ui表格el-table-column在里面做判斷問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08

