首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

移动端那些戳中你痛点的软键盘问题及解决方法

IOS 软键盘收起表现 触发软键盘上的“收起”按钮键盘或者输入框以外的页面区域时,输入框失去焦点,软键盘收起。 Android 软键盘收起表现 触发输入框以外的区域时,输入框失去焦点,软键盘收起。...监听输入框的 focus 事件来获知软键盘弹起,监听输入框的 blur 事件获知软键盘收起。...,否则软键盘收起。...4、ios软键盘收起时页面不能自然滑落 对于部分ios系统下的部分微信webview内,发现软键盘收起时,滚动上去的页面没有滚动下来,造成了下面区域留出了一片灰色的区域。...参考文章: WebView上软键盘的兼容方案[5] js如何获取iOS键盘高度[6] 移动端input“输入框”常见问题及解决方法[7] ios键盘难题与可见视口(visualViewport)api[

7.7K30
您找到你想要的搜索结果了吗?
是的
没有找到

【H5】209-可能这些是你想要的H5软键盘兼容方案

解决方案: 获知软键盘弹起和收起状态 获知软键盘的弹起还是收起状态很重要,后面的兼容处理都要以此为前提。...IOS 软键盘收起表现 触发软键盘上的“收起”按钮键盘或者输入框以外的页面区域时,输入框失去焦点,软键盘收起。 Android 软键盘收起表现 触发输入框以外的区域时,输入框失去焦点,软键盘收起。...但是,触发键盘上的收起按钮键盘时,输入框并不会失去焦点,同样软键盘收起。 ? ?...听软键盘弹起和收起 综合上面键盘弹起和收起在 IOS 和 Android 上的不同表现,我们可以分开进行如下处理来监听软键盘的弹起和收起: 在 IOS 上,监听输入框的 focus 事件来获知软键盘弹起...novalidate="novalidate",novalidate 属性规定当提交表单时不对其进行验证,由于 pattern 校验兼容性不好,可以不让其校验,只让其唤起纯数字键盘,校验工作由 js 去做

3.9K12

可能这些是你想要的H5软键盘兼容方案

获知软键盘弹起和收起状态 获知软键盘的弹起还是收起状态很重要,后面的兼容处理都要以此为前提。...IOS 软键盘收起表现 触发软键盘上的“收起”按钮键盘或者输入框以外的页面区域时,输入框失去焦点,软键盘收起。 Android 软键盘收起表现 触发输入框以外的区域时,输入框失去焦点,软键盘收起。...但是,触发键盘上的收起按钮键盘时,输入框并不会失去焦点,同样软键盘收起。 ?...监听软键盘弹起和收起 综合上面键盘弹起和收起在 IOS 和 Android 上的不同表现,我们可以分开进行如下处理来监听软键盘的弹起和收起: 在 IOS 上,监听输入框的 focus 事件来获知软键盘弹起...novalidate="novalidate",novalidate 属性规定当提交表单时不对其进行验证,由于 pattern 校验兼容性不好,可以不让其校验,只让其唤起纯数字键盘,校验工作由 js 去做

7.9K20

Android开发中软键盘的显示和隐藏

本篇内容通过操作软键盘的函数着手详细分析了隐藏或者显示软键盘的实现方法,并且对其中重要的代码做了详细分析。 一、开篇 如果有需要用到输入的地方,通常会有需要自动弹出或者收起软键盘的需求。...开篇明义,本文会讲讲弹出和收起软键盘的一些细节,最终还会从源码进行分析。...3.2 如何判断软键盘是否弹出 既然 toggleSoftInput() 可以根据当前软键盘的状态,进行不同的操作,那么肯定是有办法确定当前软键盘的状态的。...如果想要监听键盘的弹出和收起,可以使用 ViewTreeObserver.OnGlobalLayoutListener 这个监听,来监听布局的调整,从而判断出键盘的弹出和隐藏。这些细节有时间再聊。...四、KeyboardUtils 既然已经清楚了软键盘收起和弹出的方法细节,那我们来写一个帮助类,来解决这个问题。让你们拿到就可用。 这里提供一下 Java 版和 Kotlin 版。

2.4K10

【H5】344- 微信 H5 页面兼容性解决方案

3、ios键盘唤起,键盘收起以后页面不归位 问题详情描述: 输入内容,软键盘弹出,页面内容整体上移,但是键盘收起,页面内容不下滑 出现原因分析: 固定定位的元素 在元素内 input 框聚焦的时候...弹出的软键盘占位 失去焦点的时候软键盘消失 但是还是占位的 导致input框不能再次输入 在失去焦点的时候给一个事件 解决办法: <div class...window.scrollTo(0, Math.max(scrollHeight - 1, 0)) }, 200) } } 拓展知识: position: fixed的元素在ios里,收起键盘的时候会被顶上去...【该方法未验证】 题外话: 如果能用小程序写的页面,尽量上小程序吧,H5开发在微信开发者工具里看页面效果可能看不出问题,因为不能唤起软键盘。...会导致刚提交的代码(特别是js)效果要半个小时左右才生效。

2.6K30

微信 H5 页面兼容性解决方案

3、ios键盘唤起,键盘收起以后页面不归位 问题详情描述: 输入内容,软键盘弹出,页面内容整体上移,但是键盘收起,页面内容不下滑 出现原因分析: 固定定位的元素 在元素内 input 框聚焦的时候 弹出的软键盘占位...window.scrollTo(0, Math.max(scrollHeight - 1, 0)) }, 200) } } 拓展知识: position: fixed的元素在ios里,收起键盘的时候会被顶上去...,特别是第三方键盘 4、安卓弹出的键盘遮盖文本框 问题详情描述: 安卓微信H5弹出软键盘后挡住input输入框,如下左图是期待唤起键盘的时候样子,右边是实际唤起键盘的样子 ?...【该方法未验证】 题外话: 如果能用小程序写的页面,尽量上小程序吧,H5开发在微信开发者工具里看页面效果可能看不出问题,因为不能唤起软键盘。...会导致刚提交的代码(特别是js)效果要半个小时左右才生效。

3.2K30

微信充值页面开发总结

function () { let id = $('.input').val() if(id.length > 7){ getNick(id) } }, 1500)) 最后决定监听软键盘的下一步按钮...找到了在input外加form标签,使用form的submit事件的方法,可以监听ios软键盘发送按钮,但是安卓不行 $('#form').submit(function (e) { getNick...($('.input').val()) }) 还找到一个监听软键盘隐藏的事件 $(document).on('focusout', function () { 软键盘收起的事件处理 alert...('键盘收起') getNick($('.input').val()) }); 但是这个会导致查询昵称接口请求多次,也不合适 最后采用监听软键盘具体某个键的值的方式来处理,打印event.keyCode...来实测各个键盘对应的值,取得ios和安卓回退键值 8 ,安卓下一步按键值9,ios前往按键值13,区分判断 / 监听软键盘 keycode 回退8 安卓下一步9 ios前往13 $(document

2K10

微信H5页面兼容性解决方案

3、ios键盘唤起,键盘收起以后页面不归位 问题详情描述: 输入内容,软键盘弹出,页面内容整体上移,但是键盘收起,页面内容不下滑 出现原因分析: 固定定位的元素 在元素内 input 框聚焦的时候...弹出的软键盘占位 失去焦点的时候软键盘消失 但是还是占位的 导致input框不能再次输入 在失去焦点的时候给一个事件 解决办法: <div class...window.scrollTo(0, Math.max(scrollHeight - 1, 0)) }, 200) } } 拓展知识: position: fixed的元素在ios里,收起键盘的时候会被顶上去...【该方法未验证】 题外话: 如果能用小程序写的页面,尽量上小程序吧,H5开发在微信开发者工具里看页面效果可能看不出问题,因为不能唤起软键盘。...会导致刚提交的代码(特别是js)效果要半个小时左右才生效。

3.3K43

详解Android中获取软键盘状态和软键盘高度

详解Android中获取软键盘状态和软键盘高度 应用场景 在Android应用中有时会需要获取软键盘的状态(即软键盘是显示还是隐藏)和软键盘的高度。这里列举了一些可能的应用场景。...场景一 当软键盘显示时,按下返回键应当是收起软键盘,而不是回退到上一个界面,但部分机型在返回键处理上有bug,按下返回键后,虽然软键盘会自动收起,但不会消费返回事件,导致Activity还会收到这次返回事件...场景二 当软键盘弹出后,会将界面底部到中间的一大部分全部挡住,如果用户要查看、操作被覆盖的区域,必须先收起软键盘,这会影响用户交互。...所以并不能通过isActive()方法来判断软键盘究竟是显示还是隐藏的。要想获取软键盘的状态和软键盘的高度,只能通过间接方法实现。...监听软键盘的状态变化 在获取到软键盘的状态和高度后就可以执行需要的操作了。如重新布局按钮位置,设置变量,记录当前软键盘状态和上次软键盘隐藏时间等。

2.7K20

手机软键盘弹起导致页面变形的一种解决方案

最近用 uniapp(一种第三方 app 开发框架) 开发 app,其中一个页面有十几个 input 输入框,在点击 input 输入时,软键盘弹起,导致页面往上顶,底部的按钮也全部弹到页面上面去了,布局全被打乱...原来的样子: image.png 软键盘弹出来后: ? 在开发APP时,通常情况下页面的宽度和高度都会设为 100%,即页面高度等于屏幕高度,页面宽度等于屏幕宽度。...当 input 获取焦点时,软键盘弹出,页面高度被挤压,此时页面高度 = 屏幕高度 - 软键盘高度。所以,页面高度缩小,元素都挤压在一起,布局被打乱。...软键盘还是会弹起,因为页面最小高度被设为了 768px,所以此时总高度为 768px + 软键盘高度,超出了屏幕高度(ipad横屏屏幕高度为768px)。...等输入完,软键盘收起时,页面恢复原状。 ipad 的问题解决了,要是 APP 运行在其他手机端上呢?此时,CSS3 @media 属性就排上用场了。

2.1K40

自适应软键盘的Dialog以及监听软键盘弹起

Dialog的布局要适应软键盘的弹起2. 软键盘弹起和收下的时候都会有不同的引导,所以要在Dialog上监听软键盘的弹起。 需求的解决: 一:适应键盘的弹起。...,主要是对软键盘操作的,主要有以下属性: stateUnspecified:软键盘的状态并没有指定,系统将选择一个合适的状态或依赖于主题的设置 stateUnchanged:当这个activity出现时...,软键盘将一直保持在上一个activity里的状态,无论是隐藏还是显示 stateHidden:用户选择activity时,软键盘总是被隐藏 stateAlwaysHidden:当该Activity主窗口获取焦点时...,软键盘也总是被隐藏的 stateVisible:软键盘通常是可见的 stateAlwaysVisible:用户选择activity时,软键盘总是显示的状态 adjustUnspecified:默认设置...其实,在清单中配置的属性本质也是告诉当前界面对软键盘这种情况的处理。

3.2K30
领券