移动端input获取焦点弹出输入框时影响fixed布局的问题

Posted yanganglanyu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了移动端input获取焦点弹出输入框时影响fixed布局的问题相关的知识,希望对你有一定的参考价值。

最近在做移动端项目的时候遇到的一个问题,在点击input获取焦点弹出输入框进行输入后,再次点击input输入框时,意外的事情发生了,

页面突然跳转到确定按钮跳转的页面了,刚开始以为是点击穿透导致的,朝着这个方向一直没有等到解决。。。

经过反复研究,发现第二次点击input 时,上面有一个隐形的按钮,这是怎么回事,确定按钮怎么就跑到上面去了呢,原来是由于最外层

使用了fixed布局,而第一次点击input获取焦点时,移动端默认弹出的输入框会将fixed布局的元素顶上去。

 

解决办法:

1、如果使用的元素不是必须使用fixed布局的话可以不使用;

2、元素必须使用fixed布局时,在input获得焦点时将元素的position设置为static,失去焦点时再将元素的position设置为fixed;

$(‘#phone‘).bind(‘focus‘,function(){
    $(‘.bottom_fix‘).css(‘position‘,‘static‘);
}).bind(‘blur‘,function(){
        $(‘.bottom_fix‘).css({‘position‘:‘fixed‘,‘bottom‘:‘0‘});
});

  

以上是关于移动端input获取焦点弹出输入框时影响fixed布局的问题的主要内容,如果未能解决你的问题,请参考以下文章

Vue全家桶开发Android和IOS移动端应用常见问题解决

Vue全家桶开发Android和IOS移动端应用常见问题解决

移动端 input 获取焦点后弹出带enter(类似于搜索,确定,前往)键盘,以及隐藏系统键盘

移动端input的虚拟键盘影响布局

apicloud问题解决记录键盘弹出监听处理以及头部底部的黑色闪屏现象

h5 ios微信浏览器 input获取焦点后,收起软键盘,光标错位