gitee仓库代码
#企微开发使用微信发送自定义欢迎语表情选择#
效果图
组件使用
<template>
<div id="app">
<emotion :width="500" :content="content" @getChildInfo="getChildInfo"></emotion>
</div>
</template>
<script>
import emotion from "./components/emotion/emotion";
export default {
name: 'App',
components: {
emotion
},
data(){
return{
content:''
}
},
methods:{
//执行方法
getChildInfo(value) {
this.content = value
},
}
}
</script>
封装组件
<template>
<div :style="{width: width + 'px' }">
<el-input
style="width: 100%;"
:rows="10"
type="textarea"
placeholder="请输入内容"
v-model="contentShow"
:maxlength="maxText"
@blur="handleInputBlur"
show-word-limit
:disabled="disabled"
></el-input>
<div>
<div class="emoji-box">
<div @click="handleEmoji" class="cursor emoji-box"><img :src="emoji" alt="">添加表情</div>
<div v-if="customerStatus" class="btm cursor" @click="addCustomer">客户昵称</div>
</div>
<div style="position: relative;" v-show="showEmoji">
<div v-if="url" :style="{height: height}" class="qqface-container">
<span class="qqface-wrapper" v-for="[key, value] of Object.entries(emoijs)" :key="value">
<img :src="url" class="qqface" :class="[`qqface${value}`]" @click="input(key)">
</span>
</div>
</div>
</div>
<div v-if="!!contentShowEmoji">
<h5>效果展示</h5>
<div class="text-show-box" v-html="contentShowEmoji"></div>
</div>
</div>
</template>
<script>
import emoji from "../../utils/emoji";
import qqface from '../../assets/qqface.png'
import { deleteEmoji, qqfaceArr } from '../../utils/util'
export default {
name: "emotion",
props: {
width: {
type: Number,
default: 200,
},
content: {
type: String,
default: '',
},
button: {
type: Boolean
},
height: {
type: String,
default: '200px'
},
maxText:{
type: Number,
default: 2000,
},
customerStatus:{
type: Boolean,
default: false,
},
disabled:{
type: Boolean,
default: false,
}
},
data() {
return {
emoji: '