词条信息

admin
admin
超级管理员
最近编辑者 发短消息   

相关词条

热门词条

更多>>
宽带升级到200兆了,路由器和网线是不是需要更换?
事实上,200兆宽带需要支持千兆网络传输速率的硬件。尽管200兆与千兆相差很大,但目前网络传输速率只有百兆和千...
2019年电子商务发展4大主流趋势
随着在线零售业的竞争日趋激烈,企业和卖家只有积极利用科技趋势才能保住增长势头,立于不败之地。据市场研究公司 S...
超1亿人朋友圈“仅三天可见”
你有多少个真正称得上朋友的人?前段时间微信创始人、腾讯公司高级副总裁张小龙在年度演讲里说起关于朋友圈的一件事:...
半夜总是醒了又睡睡了又醒怎么办?
现在是一个全民缺觉的时代,越来越多人因为加班、情感、焦虑等问题困扰着自己的失眠。急剧下降的睡眠质量,同样也会影...
敬酒时,应先敬己方领导还是对方领导
敬酒时,应先敬己方领导还是对方领导?己方领导未敬酒或无敬酒意思员工该不该敬?首先看第一个问题,如果一个桌上既有...
解决网 >>所属分类 >> 移动端开发   

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

标签: 手机 输入框

顶[0] 发表评论(0) 编辑词条

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

前提

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部分编辑本段回目录


思路解析

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

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

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


“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();

 

 

附件列表


按字母顺序浏览:A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

→我们致力于为广大网民解决所遇到的各种电脑技术问题
 如果您认为本词条还有待完善,请 编辑词条

上一篇javascript函数方法大全
下一篇手机注册发送验证码倒计时的源码

0
1. 本站部分内容来自互联网,如有任何版权侵犯或其他问题请与我们联系,我们将立即删除或处理。
2. 本站内容仅供参考,如果您需要解决具体问题,建议您咨询相关领域专业人士。
3. 如果您没有找到需要的百科词条,您可以到百科问答提问或创建词条,等待高手解答。

关于本词条的提问

查看全部/我要提问>>