js手机键盘遮挡_完美解决手机网页中输入框被输入法遮挡的问题

本文介绍了如何使用JavaScript解决在手机网页中,输入框被输入法遮挡的问题。通过监听输入框焦点和窗口大小变化事件,动态调整弹出对话框的定位,确保输入框始终可见。
摘要由CSDN通过智能技术生成

之前要做一个弹出对话框,填写信息,发现在手机上看的时候,较后的输入框在填写信息时,输入框被输入法遮挡,只能盲填。

前提

1.弹出的对话框用display:fixed定位的

2.对话框大小固定

解决办法

css部分

(dlg-top与dlg-bottom为对话框的类,用于确定对话框的定位方式)

.dlg-top{

position: fixed;

top:100px;

left:10%;

}

.dlg-bottom{

position: fixed;

bottom:0px;

left:10%;

}

js部分

“deliver-dlg”为对话框的类

//弹出对话框时,绑定的事件

//绑定输入框获取焦点事件

$(".deliver-dlg input,.deliver-dlg textarea").focus(function(){

var input=$(this);

//在输入框获取焦点后,窗口改变的话,执行事件

$(window).resize(function(){

//判断当前输入框是否在可视窗口之外(下面)

if($(window).height()-(input.offset().top+input.offset().height-document.body.scrollTop)<0){

//对话框定位方式改为bottom

$(".deliver-dlg").removeClass("dlg-top").addClass("dlg-bottom");

}

else{

$(".deliver-dlg").removeClass("dlg-bottom").addClass("dlg-top");

}

});

});

//取消对话框时,取消事件绑定

$(".deliver-dlg input").unbind();

$(".deliver-dlg").removeClass("dlg-bottom").addClass("dlg-top");

$(window).unbind();

思路解析

简单点说就是改变对话框的定位方式,在默认情况下用top,在有输入法的时候,根据情况用bottom。 在input获取焦点且窗口重设的时候(即输入框弹出),注意先绑定input的focus事件,再绑定窗口改变的事件,因为在手机上,是input获取焦点,输入框才弹出导致窗口大小改变。

再窗口大小改变事件发生之后,判断输入框是否被遮(即不在窗口的可视范围内),采用的办法是用可视窗口的高度($(window).height())是否大于输入框的底部(input.offset().top+input.offset().height-document.body.scrollTop)因为input.offset().top表示的是元素离文档头部的位置,要算元素离可视窗口头部的位置,可以再减去滚动条滚动了多少。以上是判断元素是否在可视窗口底部。

以上这篇完美解决手机网页中输入框被输入法遮挡的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值