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

相关推荐
Swift社区12 小时前
H5 与 ArkTS 通信的完整设计模型
uni-app·harmonyos
小溪彼岸15 小时前
uni-app小白从0开发一款鸿蒙Next应用到上线
uni-app·harmonyos
一颗小青松17 小时前
uniapp app端使用uniCloud的unipush
uni-app
cngm11020 小时前
uniapp+springboot后端跨域以及webview中cookie调试
spring boot·后端·uni-app
iOS阿玮2 天前
“死了么”App荣登付费榜第一名!
uni-app·app·apple
wendycwb2 天前
uni-app 在真机中canvas绘制的元素悬浮,内容不随父组件滚动问题
uni-app
frontend_frank2 天前
脱离 Electron autoUpdater:uni-app跨端更新:Windows+Android统一实现方案
android·前端·javascript·electron·uni-app
三天不学习2 天前
UniApp三端实时通信实战:SignalR在H5、APP、小程序的差异与实现
微信小程序·uni-app·signalr
念你那丝微笑2 天前
uView Plus + Vue3 + TypeScript + UniApp 正确引入 UnoCSS(避坑版)
vue.js·typescript·uni-app
念你那丝微笑2 天前
vue3+ts在uniapp项目中实现自动导入 ref 和 reactive
vue.js·typescript·uni-app