大盤(pán)雞拌面--- vue 通訊中聊天表情的回顯

? ? ?最近在做一個(gè)通訊類型的項(xiàng)目,當(dāng)然離不開(kāi)表情的發(fā)送與接收。在這塊我大致說(shuō)下回顯剂陡,發(fā)送的時(shí)候你可以照著邏輯回繞下解寝,發(fā)送較為簡(jiǎn)單扛禽。著重說(shuō)下回顯,項(xiàng)目采用的是vue-cli,在做表情回顯的時(shí)候踩到了一些坑有序,在這篇文章中跟大家分享下我的解決方案握巢,當(dāng)然晕鹊,你有更好的方法也可以進(jìn)行發(fā)表評(píng)論。

? ? ?起初镜粤,我用到的方法是將聊天記錄的內(nèi)容進(jìn)行遍歷捏题。再通過(guò)管道符進(jìn)行內(nèi)置的過(guò)濾方法處理。
<div class="cl-content-text-box">  // 組件中遍歷的部分
{{ item.message | imgfilter }}
</div>
? ? ?list是我整理的表情包的數(shù)據(jù)肉渴,我拿到下標(biāo)再進(jìn)行本地圖片的獲取公荧。假設(shè)給好友發(fā)送一個(gè)哈哈的表情,我們發(fā)送給后臺(tái)的數(shù)據(jù)將是 ‘[哈哈]’這樣式的同规,接受的時(shí)候同樣也是這種格式的循狰,處理的時(shí)候?qū)?nèi)容中的‘[哈哈]’窟社,這樣的數(shù)據(jù)替換成我們本地的圖片路徑,再進(jìn)行渲染绪钥。
const imgfilter = function (val) {
  console.log(val)
  return val.replace(/\[[^\]]+\]/g, function (tmp) {
    console.log(tmp)
    let img = document.createElement('img')
    let indexOf = list.findIndex(data => data.name === tmp)
    // let str = list[indexOf].src
    img.src = `static/emoticons/Expression_" + ${indexOf} + "@2x.png`
    // var img = "<img src='static/emoticons/Expression_" + indexOf + "@2x.png'>"
    return img
  })
}
以上代碼的出的結(jié)論
? ? ? what? 什么鬼灿里。后來(lái)又根據(jù)這種形式的進(jìn)一步處理了一下,具體細(xì)節(jié)忘掉了程腹,但是還是沒(méi)達(dá)到想要的效果匣吊。中間也查了一些資料,這樣的情況目前還不知道解決辦法寸潦。

后來(lái)再處理中色鸳,也遇到了最后以字符串的形式顯示到頁(yè)面上了〖‘<img src='路徑' >’命雀。。斩箫。吏砂。有點(diǎn)扯,還不是想要的乘客,vue中的胡子語(yǔ)法支持方法狐血、表達(dá)式,但并解析不了字符串的元素寨典。果斷換了一個(gè)方案氛雪。

<div class="cl-content-text-box" v-html="$options.filters.dataImgFilter(item.message)">
</div>

使用了$options,它用于當(dāng)前 Vue 實(shí)例的初始化選項(xiàng)。需要在選項(xiàng)中包含自定義屬性時(shí)會(huì)有用耸成,我在一個(gè)自定義屬性的方法中定義了一個(gè)自定義的filter报亩,在通過(guò)v-html,他可以解析標(biāo)簽元素井氢。在pc中發(fā)送><&等弦追,這些字符他會(huì)隱式轉(zhuǎn)換成轉(zhuǎn)義字符,同樣的我們?cè)谙旅娴姆椒ㄖ幸煌瑢⑺鎿Q掉

轉(zhuǎn)義字符
filters: {
    dataImgFilter: function (val) {
      var arrEntities = {'lt': '<', 'gt': '>', 'nbsp': ' ', 'amp': '&', 'quot': '"'}
      return val.replace(/&(lt|gt|nbsp|amp|quot);/ig, function (all, t) { return arrEntities[t] })
        .replace(/\[[^\]]+\]/g, function (tmp) {
          let indexOf = EMOTIONSLIST.findIndex(data => data.name === tmp)
          var img = `<img src='/static/emoticons/Expression_${indexOf + 1}@2x.png' style="width: 20px;height: 20px;">`
          return img
        })
    }
  },
圓滿解決圖像回顯
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末花竞,一起剝皮案震驚了整個(gè)濱河市劲件,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌约急,老刑警劉巖零远,帶你破解...
    沈念sama閱讀 210,978評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異厌蔽,居然都是意外死亡牵辣,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門(mén)奴饮,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)纬向,“玉大人择浊,你說(shuō)我怎么就攤上這事∮馓酰” “怎么了琢岩?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,623評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)师脂。 經(jīng)常有香客問(wèn)我担孔,道長(zhǎng),這世上最難降的妖魔是什么危彩? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,324評(píng)論 1 282
  • 正文 為了忘掉前任攒磨,我火速辦了婚禮,結(jié)果婚禮上汤徽,老公的妹妹穿的比我還像新娘。我一直安慰自己灸撰,他們只是感情好谒府,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,390評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著浮毯,像睡著了一般完疫。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上债蓝,一...
    開(kāi)封第一講書(shū)人閱讀 49,741評(píng)論 1 289
  • 那天壳鹤,我揣著相機(jī)與錄音,去河邊找鬼饰迹。 笑死芳誓,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的啊鸭。 我是一名探鬼主播锹淌,決...
    沈念sama閱讀 38,892評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼赠制!你這毒婦竟也來(lái)了赂摆?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,655評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤钟些,失蹤者是張志新(化名)和其女友劉穎烟号,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體政恍,經(jīng)...
    沈念sama閱讀 44,104評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡汪拥,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了抚垃。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片喷楣。...
    茶點(diǎn)故事閱讀 38,569評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡趟大,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出铣焊,到底是詐尸還是另有隱情逊朽,我是刑警寧澤,帶...
    沈念sama閱讀 34,254評(píng)論 4 328
  • 正文 年R本政府宣布曲伊,位于F島的核電站叽讳,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏坟募。R本人自食惡果不足惜岛蚤,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,834評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望懈糯。 院中可真熱鬧涤妒,春花似錦、人聲如沸赚哗。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,725評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)屿储。三九已至贿讹,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間够掠,已是汗流浹背民褂。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,950評(píng)論 1 264
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留疯潭,地道東北人赊堪。 一個(gè)月前我還...
    沈念sama閱讀 46,260評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像袁勺,于是被迫代替她去往敵國(guó)和親雹食。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,446評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • Swift1> Swift和OC的區(qū)別1.1> Swift沒(méi)有地址/指針的概念1.2> 泛型1.3> 類型嚴(yán)謹(jǐn) 對(duì)...
    cosWriter閱讀 11,090評(píng)論 1 32
  • Vue 實(shí)例 屬性和方法 每個(gè) Vue 實(shí)例都會(huì)代理其 data 對(duì)象里所有的屬性:var data = { a:...
    云之外閱讀 2,204評(píng)論 0 6
  • 央行加息并不是傳統(tǒng)意義上的上調(diào)存款準(zhǔn)備金率和上調(diào)銀行基準(zhǔn)利率期丰。我們都知道借貸資金是有成本的群叶。向商業(yè)銀行借錢(qián),商業(yè)銀...
    哥德堡閱讀 271評(píng)論 1 0
  • 每張照片后面總有一個(gè)故事街立。 傍晚,在音樂(lè)廳邊上赎离,正在小聲交談的母女端辱。是在討論今晚的歌劇嗎梁剔? 音樂(lè)廳里兩個(gè)老人 在公...
    lemei閱讀 115評(píng)論 0 0
  • 這是我人生第一次的崩塌虽画,不該怨誰(shuí)?為何要怨荣病。 我毫不刻意的小心生活,于己个盆,于他人,做到?jīng)]有傷害颊亮,沒(méi)有留戀柴梆,朋友都是...
    TianaLiu閱讀 251評(píng)論 0 0