Vue實現(xiàn)圖片與文字混輸??

知識在于積累澜薄,踩坑越多侣滩,你越強??

前言

用多了JQuery,習(xí)慣了使用JQuery的API操作DOM涡真,幾乎忘記了原生JS對DOM操作分俯,今天在項目中遇到了文字和圖片混輸?shù)那闆r,第一個想到的辦法是用textarea實現(xiàn)综膀,結(jié)果發(fā)現(xiàn)實現(xiàn)不了圖片輸入澳迫,然后想著找個富文本編輯器的插件實現(xiàn),深思熟慮之后剧劝,我的需求好像也沒那么復(fù)雜橄登,不至于引用個插件,看了掘金的發(fā)布沸點功能讥此,然后就模仿了其作法拢锹,于是就有了這篇文章的分享。先給大家展示下最后實現(xiàn)的效果??

image

實現(xiàn)思路

  • 利用divcontenteditable屬性,讓div可編輯
  • 綁定ref屬性萄喳,用于操作輸入框元素
  • 圖片點擊時卒稳,獲取圖片地址,使用require轉(zhuǎn)換圖片地址
  • 創(chuàng)建img標簽他巨,賦值轉(zhuǎn)換好的圖片地址
  • refs對象中獲取到輸入框元素充坑,賦值創(chuàng)建好的img標簽

實現(xiàn)過程

  • 聲明div可編輯减江,監(jiān)聽回車鍵事件,關(guān)閉拼寫檢查捻爷,綁定ref方便獲取當前元素
    <div class="input-panel" ref="msgInputContainer" @keydown.enter.exact="sendMessage($event)"
         contenteditable="true" spellcheck="false"></div>
    
  • 表情輸入框綁定對應(yīng)的事件
    <div class="item-panel" v-for="item in this.emojiList" :key="item.info">
        <img :src="require(`../assets/img/emoji/${item.src}`)" :alt="item.info"
             @mouseover="emojiConversion($event,'over',item.src,item.hover,item.info)"
             @mouseleave="emojiConversion($event,'leave',item.src,item.hover,item.info)"
             @click="emojiConversion($event,'click',item.src,item.hover,item.info)">
    </div>
    
  • 實現(xiàn)表情框圖片點擊事件
    emojiConversion: function (event, status, path, hoverPath, info) {
        if (status === "over") {
            event.target.src = require(`../assets/img/emoji/${hoverPath}`);
        } else if (status === "click") {
            // 表情輸入
            const imgSrc = require(`../assets/img/emoji/${hoverPath}`);
             /**
             * 不推薦的寫法:
             *   無法獲取焦點
             *   無法在當前焦點的位置插入元素
             */
            // const imgTag = document.createElement("img");
            // imgTag.src = imgSrc;
            // imgTag.alt = info;
            // this.$refs.msgInputContainer.appendChild(imgTag);
            
             /**
             * 推薦使用document暴露的execCommand 方法來操作此處
             *   可以在當前焦點處插入元素
             *   感謝評論區(qū)掘友的建議
             */
            const imgTag = `<img src="${imgSrc}" width="28" height="28" alt="${info}">`;
            document.execCommand("insertHTML", false, imgTag);
        } else {
            event.target.src = require(`../assets/img/emoji/${path}`);
        }
    }
    

踩坑記錄

  • 直接使用append()方法

    公司項目一直用JQuery辈灼,類似的需求直接append,以為是js提供的方法也榄,結(jié)果這里直接使用巡莹,答案很明顯,直接將DOM字符串插入了輸入框里??

![image](https://upload-images.jianshu.io/upload_images/17630817-1db3c353fe60e0ac?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

![image](https://upload-images.jianshu.io/upload_images/17630817-94f3926034b727ee?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
  • 手動實現(xiàn)字符串轉(zhuǎn)dom

    自己手動實現(xiàn)甜紫,不知道是不是自己寫錯了降宅,結(jié)果也是行不通,如果有發(fā)現(xiàn)錯誤的朋友囚霸,歡迎評論區(qū)留言腰根。

    image
![image](https://upload-images.jianshu.io/upload_images/17630817-5416781c6373fe44?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)


![image](https://upload-images.jianshu.io/upload_images/17630817-431f950a08e06910?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
  • 正確的實現(xiàn)方法

    創(chuàng)建DOM字符串,使用document暴露的execCommand方法來插入創(chuàng)建好的DOM字符串邮辽。使用方法

寫在最后

  • 文中如有錯誤唠雕,歡迎在評論區(qū)指正贸营,如果這篇文章幫到了你吨述,歡迎點贊和關(guān)注??
  • 本文首發(fā)于掘金,如需轉(zhuǎn)載請注明出處??
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末钞脂,一起剝皮案震驚了整個濱河市揣云,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌冰啃,老刑警劉巖邓夕,帶你破解...
    沈念sama閱讀 217,907評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異阎毅,居然都是意外死亡焚刚,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,987評論 3 395
  • 文/潘曉璐 我一進店門扇调,熙熙樓的掌柜王于貴愁眉苦臉地迎上來矿咕,“玉大人,你說我怎么就攤上這事狼钮√贾” “怎么了?”我有些...
    開封第一講書人閱讀 164,298評論 0 354
  • 文/不壞的土叔 我叫張陵熬芜,是天一觀的道長莲镣。 經(jīng)常有香客問我,道長涎拉,這世上最難降的妖魔是什么瑞侮? 我笑而不...
    開封第一講書人閱讀 58,586評論 1 293
  • 正文 為了忘掉前任的圆,我火速辦了婚禮,結(jié)果婚禮上半火,老公的妹妹穿的比我還像新娘略板。我一直安慰自己,他們只是感情好慈缔,可當我...
    茶點故事閱讀 67,633評論 6 392
  • 文/花漫 我一把揭開白布叮称。 她就那樣靜靜地躺著,像睡著了一般藐鹤。 火紅的嫁衣襯著肌膚如雪瓤檐。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,488評論 1 302
  • 那天娱节,我揣著相機與錄音挠蛉,去河邊找鬼。 笑死肄满,一個胖子當著我的面吹牛谴古,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播稠歉,決...
    沈念sama閱讀 40,275評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼掰担,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了怒炸?” 一聲冷哼從身側(cè)響起带饱,我...
    開封第一講書人閱讀 39,176評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎阅羹,沒想到半個月后勺疼,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,619評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡捏鱼,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,819評論 3 336
  • 正文 我和宋清朗相戀三年执庐,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片导梆。...
    茶點故事閱讀 39,932評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡轨淌,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出问潭,到底是詐尸還是另有隱情猿诸,我是刑警寧澤,帶...
    沈念sama閱讀 35,655評論 5 346
  • 正文 年R本政府宣布狡忙,位于F島的核電站梳虽,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏灾茁。R本人自食惡果不足惜窜觉,卻給世界環(huán)境...
    茶點故事閱讀 41,265評論 3 329
  • 文/蒙蒙 一谷炸、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧禀挫,春花似錦旬陡、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,871評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至砰左,卻和暖如春匿醒,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背缠导。 一陣腳步聲響...
    開封第一講書人閱讀 32,994評論 1 269
  • 我被黑心中介騙來泰國打工廉羔, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人僻造。 一個月前我還...
    沈念sama閱讀 48,095評論 3 370
  • 正文 我出身青樓憋他,卻偏偏與公主長得像,于是被迫代替她去往敵國和親髓削。 傳聞我的和親對象是個殘疾皇子竹挡,可洞房花燭夜當晚...
    茶點故事閱讀 44,884評論 2 354

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