javascript - emoji的unicode怎么轉(zhuǎn)換成圖像
問(wèn)題描述
做一個(gè)聊天應(yīng)用,現(xiàn)在導(dǎo)入了表情包,但是遇到了一個(gè)新的問(wèn)題,就是現(xiàn)在發(fā)送只能收到emoji的Unicode碼,比如說(shuō)笑臉就是收到: smile:,那么我怎么轉(zhuǎn)換成這樣的。有沒(méi)有做過(guò)這樣項(xiàng)目的大神,分享一下經(jīng)驗(yàn)吧,先說(shuō)聲謝謝了。
問(wèn)題解答
回答1:EmojiOne支持JS PHP Android iOS Java等
JS
https://github.com/Ranks/emojione/blob/master/lib/js
還需要下載對(duì)應(yīng)的圖片或字體 https://www.emojione.com/deve...放的位置參照官方例子
使用方法emojione.shortnameToImage(':see_no_evil: or :’-) or emoji charset');支持格式
:emoji:,比如 :see_no_evil: 是那個(gè)
象形符號(hào),比如 ’:-)
unicode字符
回答2:js獲取到unicode字符之后,會(huì)對(duì)它進(jìn)行正則過(guò)濾,轉(zhuǎn)換成圖片名稱(chēng)對(duì)應(yīng)的字符,然后組裝圖片路徑,這樣就可以顯示了
回答3:weChatEmoji
var qqfaceMap = {'/::)':'0','/::~':'1','/::B':'2','/::|':'3','/:8-)':'4','/::<':'5','/::$':'6','/::X':'7','/::Z':'8','/::’(':'9','/::-|':'10','/::@':'11','/::P':'12','/::D':'13','/::O':'14','/::(':'15','/::+':'16',' /:--b':'17','/::Q':'18','/::T':'19','/:,@P':'20','/:,@-D':'21','/::d':'22','/:,@o':'23','/::g':'24','/:|-)':'25','/::!':'26','/::L':'27','/::>':'28','/::,@':'29','/:,@f':'30','/::-S':'31','/:?':'32','/:,@x':'33','/:,@@':'34','/::8':'35','/:,@!':'36','/:!!!':'37','/:xx':'38','/:bye':'39','/:wipe':'40','/:dig':'41','/:handclap':'42','/:&-(':'43','/:B-)':'44','/:<@':'45','/:@>':'46','/::-O':'47','/:>-|':'48','/:P-(':'49','/::’|':'50','/:X-)':'51','/::*':'52','/:@x':'53','/:8*':'54','/:pd':'55','/:':'56','/:beer':'57','/:basketb':'58','/:oo':'59','/:coffee':'60','/:eat':'61','/:pig':'62','/:rose':'63','/:fade':'64','/:showlove':'65','/:heart':'66','/:break':'67','/:cake':'68','/:li':'69','/:bome':'70','/:kn':'71','/:footb':'72','/:ladybug':'73','/:shit':'74','/:moon':'75','/:sun':'76','/:gift':'77','/:hug':'78','/:strong':'79','/:weak':'80','/:share':'81','/:v':'82','/:@)':'83','/:jj':'84','/:@@':'85','/:bad':'86','/:lvu':'87','/:no':'88','/:ok':'89','/:love':'90','/:':'91','/:jump':'92','/:shake':'93','/:':'94','/:circle':'95','/:kotow':'96','/:turn':'97','/:skip':'98','/:oY':'99','/:#-0':'100','/:hiphot':'101','/:kiss':'102','/:<&':'103','/:&>':'104'}; var str = '/::)|/::~|/::B|/::||/:8-)|/::<|/::$|/::X|/::Z|/::’(|/::-||/::@|/::P|/::D|/::O|/::(|/::+|/:--b|/::Q|/::T|/:,@P|/:,@-D|/::d|/:,@o|/::g|/:|-)|/::!|/::L|/::>|/::,@|/:,@f|/::-S|/:?|/:,@x|/:,@@|/::8|/:,@!|/:!!!|/:xx|/:bye|/:wipe|/:dig|/:handclap|/:&-(|/:B-)|/:<@|/:@>|/::-O|/:>-||/:P-(|/::’||/:X-)|/::*|/:@x|/:8*|/:pd|/:<W>|/:beer|/:basketb|/:oo|/:coffee|/:eat|/:pig|/:rose|/:fade|/:showlove|/:heart|/:break|/:cake|/:li|/:bome|/:kn|/:footb|/:ladybug|/:shit|/:moon|/:sun|/:gift|/:hug|/:strong|/:weak|/:share|/:v|/:@)|/:jj|/:@@|/:bad|/:lvu|/:no|/:ok|/:love|/:<L>|/:jump|/:shake|/:<O>|/:circle|/:kotow|/:turn|/:skip|/:oY|/:#-0|/:hiphot|/:kiss|/:<&|/:&>'; var reg = new RegExp(str,’g’); result = ’這是簡(jiǎn)單的測(cè)試/::Z呵呵/:wipe效果不錯(cuò)吧’.replace(reg,function(r){return ’<img src='http://www.aoyou183.cn/wenda/images/qqface/’+qqfaceMap[r]+’.png' />’; }); var a = document.getElementsByTagName(’p’)[0]; a.innerHTML = result;
https://github.com/hu-qi/weCh...
相關(guān)文章:
1. Docker for Mac 創(chuàng)建的dnsmasq容器連不上/不工作的問(wèn)題2. docker安裝后出現(xiàn)Cannot connect to the Docker daemon.3. css - 定位為absolute的父元素中的子元素 如何設(shè)置在父元素的下面?4. javascript - angualr2中emit觸發(fā)一個(gè)方法然后怎么獲得這個(gè)promise的結(jié)果5. java - 請(qǐng)問(wèn)在main方法中寫(xiě)成對(duì)象名.屬性()并賦值,與直接參參數(shù)賦值輸錯(cuò)誤是什么原因?6. mysql里的大表用mycat做水平拆分,是不是要先手動(dòng)分好,再配置mycat7. java - Spring boot 讀取 放在 jar 包外的,log4j 配置文件,系統(tǒng)有創(chuàng)建日志文件,不寫(xiě)入日志信息。8. javascript - 圖片鏈接請(qǐng)求一直是pending狀態(tài),導(dǎo)致頁(yè)面崩潰,怎么解決?9. python - beautifulsoup獲取網(wǎng)頁(yè)內(nèi)容的問(wèn)題10. 怎么用css截取字符?
