uniapp富文本editor在插入emoji表情后,如何不显示软键盘?

在选择emoji表情后,刚开始用的是insertText{text:emoji表情},表情是插入了,但是由于输入框有了焦点,自动弹出了软键盘,并且收起了emoji表情面板,如果需要再次选emoji很麻烦,得再次点击emoji选择面板按钮。

后来富文本editor 加了:read-only="isReadOnly",选择emoji表情后readOnly设置为true,由于富文本状态为只读,导致insertText无法插入表情。

javascript 复制代码
<editor id="editor" class="send-text-area" :placeholder="isReceipt ? '[回执消息]' : ''"
						:read-only="isReadOnly" @focus="onEditorFocus" @blur="onEditorBlur" @ready="onEditorReady"
						@input="onTextInput">
					</editor>
<scroll-view v-if="chatTabBox === 'emo'" class="chat-emotion" scroll-y="true"
				:style="{height: keyboardHeight+'px'}">
				<view class="emotion-item-list" v-for="(items, i) in emoList" :key="i">
					<block v-for="(item, index) in items" :key="index">
						<view class="emoj_parent" hover-class="checkActive" @click="tuchEmoj(item)">
							<text class="emoj_conn">{{item}}</text>
						</view>
					</block>
				</view>
			</scroll-view>

最终使用下面方法解决了。

选择emoji表情后将富文本修改为只读,防止有焦点弹出软键盘。getContents方法获取editor内容,拼接emoji表情后setContents方法重新设置editor内容,完成后,修改富文本状态为可写,使用blur方法使富文本编辑器失去焦点。

javascript 复制代码
tuchEmoj(item) {
				this.isReadOnly = true;
				this.$nextTick(() => {
					this.editorCtx.getContents({
						success: (res) => {
							this.editorCtx.setContents({
								html: res.text + item,
								complete: () => {
									this.isReadOnly = false
									this.editorCtx.blur()
								}
							})
						}
					})
				})
			}

这种的话软键盘不会突然闪现,也不会由于readonly为只读导致无法插入emoji表情。

效果: https://live.csdn.net/v/494264

相关推荐
带着梦想扬帆启航5 小时前
UniApp 全局使用字体教程
css·uni-app
Best5 小时前
uniapp 微信小程序记录
微信小程序·小程序·uni-app
shykevin7 小时前
uni-app x开发商城系统,商品列表点击跳转至商品详情页
windows·uni-app
蜕变菜鸟7 小时前
PC网站和uniapp安卓APP、H5接入支付宝支付
uni-app
狼性书生8 小时前
uniapp实现的Tab 选项卡组件模板
前端·uni-app·vue·组件·插件
糖糖24611 小时前
uniapp + uni-ui + vue3转cli
uni-app
多秋浮沉度华年11 小时前
uni-app开发app移动端使用ucharts自定义标签栏Tooltip
uni-app
2501_9160074713 小时前
手机使用过的痕迹能查到吗?完整查询指南与步骤
android·ios·智能手机·小程序·uni-app·iphone·webview
Amewin19 小时前
在vue3+uniapp+vite中挂载全局属性方法
javascript·vue.js·uni-app
2501_915106321 天前
App HTTPS 抓包 工程化排查与工具组合实战
网络协议·ios·小程序·https·uni-app·php·iphone