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

相关推荐
qq_229933135 小时前
uniapp踩坑-组件嵌套子组件不触发onReachBottom事件
uni-app
00后程序员张6 小时前
Jenkins 自动上传 IPA 到 App Store 把发布步骤融入 CI/CD
android·ios·小程序·https·uni-app·iphone·webview
JackieDYH6 小时前
uniapp vue3 常用的生命周期和作用使用时机
javascript·vue.js·uni-app
PedroQue997 小时前
uni-app路由管理神器:vue-router风格体验
前端·uni-app
chéng ௹8 小时前
uniapp封装火山引擎 DataRangers 埋点 SDK
uni-app·apache·火山引擎
2501_915909069 小时前
iOS IPA文件反编译与打包操作方法详解
android·ios·小程序·https·uni-app·iphone·webview
2501_915921431 天前
uni-app 上架 iOS 的完整流程(无需依赖 Mac)
android·macos·ios·小程序·uni-app·iphone·webview
于先生吖2 天前
前后端分离二手商城开发,质检登记、回收回款整套业务源码部署教程
java·开发语言·uni-app
Geek_Vison2 天前
政务一网通APP如何引入AI能力,通过一个AI助手就能够调用所有的功能,实现对话即办事
人工智能·ai·小程序·uni-app·小程序容器
狗凯之家源码网3 天前
UniApp 数藏系统源码部署与定制开发全指南
uni-app