uni-app使用uView打开弹出层后输入框聚焦时placeholder错位问题

这里就不放效果了,大概意思就是在使用uView的popus时,在底部弹出后,如果弹窗中的输入框会造成一瞬间的placeholder文字错位,这个问题的主要是因为uView安全区适配导致

uView相关文档

python 复制代码
https://www.uviewui.com/components/safeAreaInset.html

popus源码

它会自动判断在并且在IPhone X等机型的时候,给元素加上一个适当底部内边距,从而为了防止用户点击相关按钮时候误触。就像这样:

可以在真机测试的时候通过真机控制台删除安全距离生成元素,就会发现已经没有了之前的placeholder错位问题

解决方案:
popup组件中动态绑定safeAreaInsetBottom的值,在每次键盘高度变化的时候取反,并且在每次键盘失去焦点的时候恢复底部安全距离,从而实现页面上推,键盘弹出时候,因为安全距离而导致的placeholder错位问题

html 复制代码
<u-popup :show="show" @open="popupOpen" :safeAreaInsetBottom="safeArea">
js 复制代码
data() {
	return {
		safeArea: true
	}
},
js 复制代码
// 键盘高度变化事件(解决iphoneX底部安全距离导致的placeholder错位问题)
keyboardheightchange() {
	this.safeArea = !this.safeArea
},
// 输入框失焦
inputBlur() {
	this.safeArea = true
},
相关推荐
手握风云-4 分钟前
JavaEE 进阶第七期:Spring MVC - Web开发的“交通枢纽”(一)
前端·spring·java-ee
Rysxt_7 分钟前
Vue 集成富文本编辑器教程
前端·javascript·vue.js·富文本
开发者小天10 分钟前
React中的受控组件示例
前端·javascript·react.js
奋斗吧程序媛11 分钟前
request请求相关
前端·javascript·vue.js
dragoooon3411 分钟前
[Linux网络基础——Lesson9.「TCP 全连接队列与 tcpdump 抓包」]
前端·git·github
光影少年17 分钟前
用vite还是webpack多,vite为什么快
前端·webpack·node.js
waeng_luo18 分钟前
[鸿蒙2025领航者闯关] 鸿蒙应用中如何管理组件状态?
前端·harmonyos·鸿蒙·鸿蒙2025领航者闯关·鸿蒙6实战·开发者年度总结
克喵的水银蛇19 分钟前
Flutter 通用列表项封装实战:适配多场景的 ListItemWidget
前端·javascript·flutter
WX-bisheyuange21 分钟前
基于Spring Boot的宠物商城网站设计与实现
前端·javascript·vue.js·毕业设计
9号达人21 分钟前
大家天天说的'银弹'到底是个啥?看完这篇你就明白了
前端·后端·程序员