关于移动端的文本框获取焦点时导致fixed或absolute定位的按钮被手机键盘顶上去的问题

本文主要是介绍关于移动端的文本框获取焦点时导致fixed或absolute定位的按钮被手机键盘顶上去的问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Write By Monkeyfly

以下内容均为原创,如需转载请注明出处。

前提

当在安卓手机上访问如图1所示的页面时,会出现如图2所示的现象。【苹果手机并不会出现该现象】
即当文本框(指inputtextarea)获取焦点时,手机自带的键盘会被唤起并且弹出来。
此时,就会导致一个问题:处于absolute(绝对)定位fixed(固定)定位的按钮,会被键盘顶上去,漂浮于键盘上方。

图1(正常情况,谷歌浏览器手机模拟器打开)
这里写图片描述

图2(在安卓手机上调试)

这里写图片描述

由于是第一次碰到该问题,也不知道怎么处理,于是百度了一下,最终找到了答案。

解决方法一:

动态监控浏览器窗口的变化。当浏览器窗口的大小发生变化时,如果变化后的窗口高度小于初始的窗口高度,则让按钮隐藏起来;反之,则让按钮正常显示。

相关代码如下所示:

var win_h = $(window).height();//关键代码
window.addEventListener('resize', function () {if($(window).height() < win_h){$('.share-btn-box').hide();}else{$('.share-btn-box').show();}
});

涉及到的知识点:

  • $(window).height()方法
  • jQuery中的resize()方法
知识点1

有些朋友可能会有疑问了:为什么要用$(window).height()而不用 $(document).height()呢?
原因:

  • 首先,我们要知道:jQuery中的height()方法获取到的是浏览器可见区域的高度
  • 其次,$(document).height() 表示整个文档的高度。
  • $(window).height() 表示浏览器可视窗口的高度。

注意:
当浏览器窗口的大小改变时,$(window).height()会随之改变,但是$(document).height()是始终不变的。

还是不懂的可以看下这两篇文章:

知识点2

当调整浏览器窗口的大小时,发生 resize 事件。
resize()方法规定了当发生 resize 事件时运行的函数。

用法:

$(window).resize(function() {});

解决方法二:

后来问同事,他给我的方法如下所示:

//navigator.userAgent.indexOf用来判断浏览器类型
var isAndroid = navigator.userAgent.indexOf('Android') > -1 || navigator.userAgent.indexOf('Adr') > -1;
if (isAndroid){//如果是安卓手机的浏览器var win_h = $(window).height();//关键代码$("body").height(win_h);//关键代码window.addEventListener('resize', function () {// Document 对象的activeElement 属性返回文档中当前获得焦点的元素。if (document.activeElement.tagName === 'INPUT' || document.activeElement.tagName === 'TEXTAREA') {if($('.share-btn-box').is(':visible')){$('.share-btn-box').hide();}else{$('.share-btn-box').show();}}});
}

在这里附上相关属性的说明:HTML DOM activeElement 属性 | 菜鸟教程

结束语

经过测试,两种方法都可行。由于第一种方法代码量少,看起来比较简单一点,我就选用了第一种方法。大家可以根据自己的需求自行选择。

这篇关于关于移动端的文本框获取焦点时导致fixed或absolute定位的按钮被手机键盘顶上去的问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
http://www.chinasem.cn/article/837823

相关文章

如何解决idea的Module:‘:app‘platform‘android-32‘not found.问题

《如何解决idea的Module:‘:app‘platform‘android-32‘notfound.问题》:本文主要介绍如何解决idea的Module:‘:app‘platform‘andr... 目录idea的Module:‘:app‘pwww.chinasem.cnlatform‘android-32

kali linux 无法登录root的问题及解决方法

《kalilinux无法登录root的问题及解决方法》:本文主要介绍kalilinux无法登录root的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录kali linux 无法登录root1、问题描述1.1、本地登录root1.2、ssh远程登录root2、

SpringMVC获取请求参数的方法

《SpringMVC获取请求参数的方法》:本文主要介绍SpringMVC获取请求参数的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下... 目录1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、@RequestParam4、@

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

使用Python实现全能手机虚拟键盘的示例代码

《使用Python实现全能手机虚拟键盘的示例代码》在数字化办公时代,你是否遇到过这样的场景:会议室投影电脑突然键盘失灵、躺在沙发上想远程控制书房电脑、或者需要给长辈远程协助操作?今天我要分享的Pyth... 目录一、项目概述:不止于键盘的远程控制方案1.1 创新价值1.2 技术栈全景二、需求实现步骤一、需求

Pyserial设置缓冲区大小失败的问题解决

《Pyserial设置缓冲区大小失败的问题解决》本文主要介绍了Pyserial设置缓冲区大小失败的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录问题描述原因分析解决方案问题描述使用set_buffer_size()设置缓冲区大小后,buf

resultMap如何处理复杂映射问题

《resultMap如何处理复杂映射问题》:本文主要介绍resultMap如何处理复杂映射问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录resultMap复杂映射问题Ⅰ 多对一查询:学生——老师Ⅱ 一对多查询:老师——学生总结resultMap复杂映射问题

Python获取C++中返回的char*字段的两种思路

《Python获取C++中返回的char*字段的两种思路》有时候需要获取C++函数中返回来的不定长的char*字符串,本文小编为大家找到了两种解决问题的思路,感兴趣的小伙伴可以跟随小编一起学习一下... 有时候需要获取C++函数中返回来的不定长的char*字符串,目前我找到两种解决问题的思路,具体实现如下:

java实现延迟/超时/定时问题

《java实现延迟/超时/定时问题》:本文主要介绍java实现延迟/超时/定时问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java实现延迟/超时/定时java 每间隔5秒执行一次,一共执行5次然后结束scheduleAtFixedRate 和 schedu