码迷,mamicode.com
首页 > 移动开发 > 详细

手机浏览器浏览WebApp弹出的键盘遮盖住文本框的解决办法

时间:2017-01-06 16:51:50      阅读:2349      评论:0      收藏:0      [点我收藏+]

标签:bar   window   cti   隐藏   浏览器   visible   工具   textarea   footer   

手机浏览器浏览WebApp弹出的键盘遮盖住文本框的解决办法

最近碰到Android微信内置浏览H5页面,因为其中的文本输入框(input)放置在靠近页面的中下方,点击文本框以后,则输入框会被弹出的手机输入法键盘遮盖住。

找到一段js代码直接解决之,点击时强制滚动之,好像也解决了在Android浏览器下浏览的同样问题。

 

技术分享
1 if(/Android [4-6]/.test(navigator.appVersion)) {
2     window.addEventListener("resize", function() {
3         if(document.activeElement.tagName=="INPUT" || document.activeElement.tagName=="TEXTAREA") {
4             window.setTimeout(function() {
5                 document.activeElement.scrollIntoViewIfNeeded();
6             },0);
7         }
8     })
9 }
技术分享

 

补充一段代码:对于某些页面,由于页面设计底部可能有工具栏(比如某些页面固定了一个footer在底部),这时候虽然系统计算出来不需要滚动,但弹出输入法时,底部的工具栏却移动上去正好遮盖住输入框(常见于输入框正好在页面中部的情况)。
这时候可以通过判断屏幕高度变化来隐藏该底部工具栏。

    <script type="text/javascript">
        document.write( ‘<style>#footer{visibility:hidden}@media(min-height:‘ + ($( window ).height() - 10) + ‘px){#footer{visibility:visible}}</style>‘ );
    </script>

手机浏览器浏览WebApp弹出的键盘遮盖住文本框的解决办法

标签:bar   window   cti   隐藏   浏览器   visible   工具   textarea   footer   

原文地址:http://www.cnblogs.com/yonina/p/6256442.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!