安卓输入框被虚拟键盘挡住的问题(微信开发)

 更新时间:2016年04月18日 14:29:27   作者:余小弟  
这篇文章主要介绍了安卓输入框被虚拟键盘挡住的问题(微信开发)的相关资料,需要的朋友可以参考下

先通过一个页面看下事情的来龙去脉,页面如下所示:

 

这个页面刚好一屏幕大小,所以没有滚动条,因为“保存”键上面那个项目备注是需要用户去填写的,当他点击后就会出现虚拟键盘,但安卓手机弹出键盘会遮住这个输入框,以至于用户看不见了。苹果手机天然不会喔,苹果手机的键盘弹出来是占了下面的位置,从而把页面推了上去,整个页面就缩小了就不会出现这样的情况。安卓手机情况如下图:

 

我不停尝试去解决这个问题,但最终都不成功。

思考一:

如果能模仿苹果一样,当键盘弹出来的时候,将整个页面缩小成页面底部刚好贴着键盘,那就完美了。但是这个想法最大的问题就是,不能准确拿到虚拟键盘的高度(后来测试时发现,虚拟键盘原来还可以改变大小……所以这个高度更不可能拿到了……),但即使拿到高度,能完成当备注那个textarea onfocus时,键盘弹出并准确计算成整个页面缩小成页面底部刚好贴着键盘这个效果,还有一个最终大坑!就是没有办法监听到虚拟键盘什么时候被用户收起来!这样一来就不知道什么时候去还原这个页面了……虽然onblur事件可以在失去焦点时去还原这个页面,但安卓用户的习惯操作应该是按手机上的物理返回键或者虚拟键盘上的那个收起键盘的按钮,问题是无论返回还是收起键盘,焦点还是在那里,没有失去呀,这就没办法了……所以最终的问题关键是,怎样监听到虚拟键盘……

思考二:

尝试了一个方法效果已经很接近了。代码如下:

<div id="fix-hegiht" style="height: 300px; width: 100%; display: none;"></div>

其实就是在文本框onfocus时,把上面这个空白高度的div显示出来,于是就能把页面撑高,就会出现滚动条,效果挺好如下图:

而且收键盘后,竟然页面会回到顶部(我怀疑触发了resize事件,但经测试,无论键盘弹出收起都没触发哎,遗憾),这不就是想要的效果了吗!如下图:

 

会发现虽然回到了顶部,看起来好像跟一开始没有滚动条的样子一样,但现在用户是可以滚动的,因为那个负责撑高的空div仍然在那里,如果用户滚下去就会看到一大片空白,这肯定是要处理掉的。于是问题又到了“什么时候去删了这个空div”?最好的当然是能监听到键盘什么时候被收起来啦,但这个似乎不太可能。于是我想,能不能当滚动条滚动到空div的地方就把它删了。确实可以这样子,但体验不好啊,突然就闪了一下,而且,如果当用户弹出键盘时去操作可以滚动的页面,滚到空div的地方就删了这个div,那瞬间输入框又被盖住了……

我还想,能不能滚动条滚到空div的地方,就不能往下滚了呢?如果这样,用户滚不下去,那留着这个空白div也没问题啊。但是这个想法却实现不了,搞来搞去没办法搞出来。

思路三:

我就想这个虚拟键盘挡住输入框的问题应该到处可见啊,各种注册页面估计都有,那怎么会这么多年来都用安卓的我竟然没觉得这是个问题!?于是我跑去随便找一个注册页面(如搜狐邮箱)http://wap.mail.sohu.com/,截图如下:

 

竟然可以!?整个页面往上挪了一点,但没出现滚动条!!这究竟是怎么做到的!!??我就奇怪是不是浏览器问题,因为这个是手机自带的浏览器访问的。于是我开微信,然后点开这个网站,果然如下图:

 

原来是微信的浏览器就会这样子……最后跑去QQ浏览器那里看,也有人问这个问题,估计是X5内核升级之后的BUG……最后为了能使用,还是将就使用空白div撑高的方法。在寻找解决方法的过程中,还发现有段很漂亮的代码。来自http://efe.baidu.com/blog/mobile-fixed-layout/ 也许以后会用上,可以用来判断滚动条是否到某个位置,还有滑动的方向,以此来判断什么时候阻止滚动条滚动。代码已经过详细注释:

<script type="text/javascript"> 
// 防止内容区域滚到底后引起页面整体的滚动 
var content = document.querySelector('main'); 
var startY; 
content.addEventListener('touchstart', function (e) { 
//起始位置 
startY = e.touches[0].clientY; 
}); 
content.addEventListener('touchmove', function (e) { 
// 高位表示向上滚动 
// 底位表示向下滚动 
// 1容许 0禁止 
var status = '11'; 
var ele = this; 
//当前位置 
var currentY = e.touches[0].clientY; 
//如果垂直偏移量scrollTop为0,说明要么内容小于容器没有滚动条,要么大于容器但滚动条在顶部 
if (ele.scrollTop === 0) { 
// 如果内容小于容器则同时禁止上下滚动,若大于则可以向下滚动 
status = ele.offsetHeight >= ele.scrollHeight ? '00' : '01'; 
} else if (ele.scrollTop + ele.offsetHeight >= ele.scrollHeight) { 
/* 
1.垂直偏移量scrollTop+整个元素的尺寸offsetHeight(包括边框)=整个内容区域scrollHeight 
证明已经滚到底部了只能向上滚动; 
2.其中offsetHeight(包括边框)是否要换成clientHeight(不包括边框)? 
*/ 
status = '10'; 
} 
//若status==11则上面三种情况都不是,这种情况是有滚动条且滚动条不在顶部也不在底部 
if (status != '11') { 
// 判断当前的滚动方向 
var direction = currentY - startY > 0 ? '10' : '01'; 
/* 
1.操作方向和当前允许状态求与运算,运算结果为0,就说明不允许该方向滚动,则禁止默认事件,阻止滚动 
2.status为00,说明没有滚动条,此时无论direction是上还是下,都要阻止滚动 
3.status为01,说明有滚动条,可以向下滚动,此时direction为01则符合向下滚动 
4.status为10,说明有滚动条,可以向上滚动,此时direction为10则符合向上滚动 
5.综上a.没有滚动条 b.滚动条在顶部但还向上滚动 c.滚动条在底部但还向下滚动 都要阻止滚动 
*/ 
if (!(parseInt(status, 2) & parseInt(direction, 2))) { 
stopEvent(e); 
} 
} 
}); 
</script>

这里用到了HTML5的touch事件,分别touch事件有四个:touchstart、touchmove、touchend、touchcancel。当你滑动屏幕的时候,他们的触发顺序是:

touchstart:当手指接触屏幕时触发

touchmove:当已经接触屏幕的手指开始移动后触发

touchend:当手指离开屏幕时触发

touchcancel:当某种touch事件非正常结束时触发

 

所以可以通过上图这些属性去获取touch时的位置。

以上内容给大家介绍了安卓输入框被虚拟键盘挡住的问题(微信开发),希望对大家有所帮助!

相关文章

  • android手机获取唯一标识的方法

    android手机获取唯一标识的方法

    这篇文章主要 为大家详细介绍了android手机获取唯一标识的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-06-06
  • Android引入OpenCV的示例

    Android引入OpenCV的示例

    本篇文章主要介绍了Android引入OpenCV的示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-01-01
  • 微信支付终于成功了(安卓、iOS)在此分享

    微信支付终于成功了(安卓、iOS)在此分享

    在此分享一篇关于微信支付终于成功了的文章,感兴趣的小伙伴们可以参考一下
    2016-02-02
  • Android 沉浸式状态栏及悬浮效果

    Android 沉浸式状态栏及悬浮效果

    这篇文章主要介绍了Android 沉浸式状态栏及悬浮效果的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-11-11
  • Android Bitmap的加载优化与Cache相关介绍

    Android Bitmap的加载优化与Cache相关介绍

    这篇文章主要介绍了Android中性能优化之Bitmap的加载优化与Cache相关内容介绍,文中介绍的很详细,对大家具有一定的参考价值,需要的朋友们下面来一起看看吧。
    2017-02-02
  • Android QQ登录界面绘制代码

    Android QQ登录界面绘制代码

    这篇文章主要为大家详细介绍了Android QQ登录界面绘制代码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • Kotlin协程启动createCoroutine及创建startCoroutine原理

    Kotlin协程启动createCoroutine及创建startCoroutine原理

    这篇文章主要为大家介绍了Kotlin协程启动createCoroutine及创建startCoroutine原理详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • Android ProductFlavor的使用详解

    Android ProductFlavor的使用详解

    如果你的项目需要要区分国内版和国外版甚至还要根据用户是否是VIP会员加上收费和免费的版本,我们可以使用ProductFlavor对UI布局和icon图标进行版本区分,有此类需求的朋友,不妨了解下本文
    2021-06-06
  • Android 代码一键实现银行卡绑定功能

    Android 代码一键实现银行卡绑定功能

    这篇文章主要介绍了Android 代码一键实现银行卡绑定功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-04-04
  • Android开发保存QQ密码功能

    Android开发保存QQ密码功能

    这篇文章主要为大家详细介绍了Android开发保存QQ密码功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04

最新评论