先看效果图

代码
参考:
html元素contenteditable属性如何定位光标和设置光标
【JavaScript编程】Selection对象和Range对象
<template>
<div class="emoji-container clearfix">
<div class="input-area" ref="editableInputAreaDiv" contenteditable="true">
123456789
<img src="https://cdn.sunofbeaches.com/emoji/1.png" alt="">
</div>
<div class="input-area-bar">
<span class="emoji-txt" @click="emojiShow=!emojiShow">表情</span>
<span class="emoji-btn" @click="publish">发布</span>
</div>
<div class="emoji-item-container" v-show="true">
<div class="emoji-item-area">
<img v-for="(emoji,key) in 130" :key="key"
@click="addEmoji(emoji)"
:src="'https://cdn.sunofbeaches.com/emoji/'+emoji+'.png'" alt=""/>
</div>
</div>
</div>
</template>
<script>
export default {
name: "Emoji",
data() {
return {
emojiShow: false,
lastEditRange: null,
}
},
mounted() {
this.$refs['editableInputAreaDiv'].onclick = ()=> {
// 获取选定对象
let selection = window.getSelection()
// 设置最后光标对象
if (selection.rangeCount > 0) {
this.lastEditRange = selection.getRangeAt(0);
}
}
},
methods: {
publish() {
this.$refs['editableInputAreaDiv'].focus()
let selection = window.getSelection()
},
addEmoji(emoji) {
let edit = this.$refs['editableInputAreaDiv']
let emojiInput = this.$refs['inputBox']
edit.focus()
let selection = window.getSelection()
if (this.lastEditRange) {
console.log('last');
// 存在最后光标对象,选定对象清除所有光标并添加最后光标还原之前的状态
selection.removeAllRanges();
selection.addRange(this.lastEditRange);
} else {
console.log('new')
let img = document.createElement('img');
img.src = 'https://cdn.sunofbeaches.com/emoji/' + emoji + '.png';
console.log(img);
edit.appendChild(img)
selection.selectAllChildren(edit)
selection.collapseToEnd()
return
}
let img = document.createElement('img');
img.src = 'https://cdn.sunofbeaches.com/emoji/' + emoji + '.png';
console.log(img);
let image = new Image();
image.src = 'https://cdn.sunofbeaches.com/emoji/' + emoji + '.png';
var range = selection.getRangeAt(0);
range.insertNode(img)
// range.insertNode(image)
range.collapse(false)
this.lastEditRange = selection.getRangeAt(0);
}
}
}
</script>
<style scoped lang="scss">
.emoji-container {
width: 400px;
height: 160px;
margin: 10px auto;
border-radius: 5px;
padding: 10px;
background-color: #fff;
::v-deep .input-area {
height: 100px;
border: 1px solid #e9e9e9;
outline: none;
padding: 10px;
font-size: 16px;
overflow-y: scroll;
&:focus {
border: 1px solid red;
}
img {
width: 20px;
height: 20px;
vertical-align: bottom;
margin: 0 2px;
}
}
.input-area-bar {
display: flex;
justify-content: space-between;
align-items: center;
margin: 10px 5px;
line-height: 20px;
height: 30px;
.emoji-txt {
color: #4485f9;
cursor: pointer;
}
.emoji-btn {
background-color: #4485f9;
cursor: pointer;
padding: 0px 10px;
color: #fff;
height: 100%;
line-height: 28px;
border-radius: 5px;
}
}
}
.emoji-item-container {
background-color: #fff;
height: 200px;
border-radius: 5px;
padding: 5px;
overflow-y: auto;
margin-top: 14px;
box-shadow: 0 0 5px 5px rgba(0, 0, 0, .028);
.emoji-item-area {
img {
cursor: pointer;
width: 20px;
height: 20px;
margin: 2px;
padding: 9px;
border-radius: 8px;
vertical-align: bottom;
transition: all .28s;
&:hover {
transform: scale(1.2);
}
&:hover {
background-color: #eaeaea;
}
}
}
}
.clearfix::before,
.clearfix::after {
content: "";
display: table;
clear: both;
}
::-webkit-scrollbar {
width: 4px;
}
::-webkit-scrollbar-thumb {
border-radius: 10px;
box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.12);
background: rgba(0, 0, 0, 0.2);
}
/*::-webkit-scrollbar-track {
box-shadow: inset 0 0 5px rgba(0,0,0,0.2);
border-radius: 10px;
background: rgba(0,0,0,0.1);
}*/
</style>
版权声明:本文为qq_16992475原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。