最近遇到了一个移动前端的BUG:手机弹出框中的输入框focus时光标可能会错位。

刚开始时我完全不知道错误原因是什么,在电脑上调试时完全没有问题,手机上出现问题时也没有找到规律。后来在网上搜索了大量的资料,终于在几篇中文文章中找到了问题的大致方向在于"fixed定位的弹出框在苹果手机系统中有问题”,但是并没有很好的解决方法,解释的bug原因也个有千秋。最后,我谷歌了“fixed input cursor"之类的关键词,终于找到了一篇英文的详细解答(文章链接),并且我也验证了其中的正确性。接下来,我就写写我得到的有用信息和自己的体会,不是直接翻译。

BUG

如果你选中一个在fixed定位的container中的input,此时会跳出键盘,如果你的input在比较下面的位置,你就不得不滚动界面,此时你就会发现光标错位,而且滚动越多,错位越厉害。

没有完美的解决方法,首先把IOS升级到11.3吧

该BUG存在于IOS系统的版本11.0至11.2X(10或者更早以前应该是没有这个BUG的,至于具体是哪个版本时出现的BUG我也不清楚,因为我很久才更新一次系统,前面提到的文章中也没有明确指出),IOS最新版本11.3已修复此BUG。我尝试过一个安卓系统的手机,没有这个BUG。我的手机几个月前是没有出现这个BUG的,后来升级过一次手机系统到11.26就发现了这个BUG,不幸的是我们公司的人大多用的苹果手机且手机系统都是11.XX于是都有这个BUG,导致我有大概一个月的时间完全没有联想到是手机系统导致的BUG。最后,我将手机升级到最新版本11.3之后,这个BUG真的不存在了!(然后我就去劝公司其他人升级手机系统)

以下有我查到的几种别的方法及我的一些见解:

1. 基本上所有文章都指出解决方法就是将 position: fixed; 变成 position: absolute; ,但是这样的话在电脑大屏幕上弹出框就不在固定位置会显得不像弹出框(或者检测屏幕宽度和高来定义是否是手机界面?);

2. 放弃使用弹出框,但是此方法可能会导致巨大的工作量以及不美观;

3. 当弹出框出现时,全屏显示,并且将其余部分用 display: none; 隐藏。这个方法的工作量可能也会很大,我们公司平台用了很多弹出框,如果要这么做的话成本太大,不过我前面提到的那篇文章的作者说他采取了这个方法并且可行。

当然,你的客户可能在用有此BUG的系统,你也不能迫使他们升级

目前我们公司的做法是将这个问题放在一边了,就我而言,我们的客户中用苹果手机的不多(客户大部分是生活在巴黎的人,感觉用华为的人好像更多),而系统恰好在11.0-11.2X的人就更少了,而且他们未来也会升级手机系统。

苹果手机iOS11中fixed弹出框中input光标错位问题的更多相关文章

  1. 在IOS11中position:fixed弹出框中的input出现光标错位的问题

    问题出现的背景: 在IOS11中position:fixed弹出框中的input出现光标错位的问题 解决方案 一.设计交互方面最好不要让弹窗中出现input输入框: 二.前端处理此兼容性的方案思路: ...

  2. IOS中position:fixed弹出框中的input出现光标错位的问题

    解决方案是 在弹框出现的时候给body添加fixed <style type="text/css"> body{ position: fixed; width: 100 ...

  3. JSP中添加弹出框

    JSP中添加弹出框 %> <script language="javascript" type="text/javascript"> aler ...

  4. ckfinder在IE10,IE9中的弹出框不能选择,或者不能上传解决方法

    在IE9,或IE10中ckfinder在IE10,IE9中的弹出框不能选择,或者不能上传解决方法   把弹出框嵌入到jquery dialog中.可以解决 I did: // javascript f ...

  5. 弹出框中选项卡的运用(easyUI)

    先看一下页面效果: 此处有两个知识点:一个是弹出框的运用,一个是选项卡的运用 分析一下该HTML代码,最外面一个div是弹出框的,默认是关闭状态,可通过ID来控制弹出框的开关,该div的样式是easy ...

  6. 弹出框中的AJAX分页

    $(function() { $("body").on("click",".set-topic",function(){ /*获取所有题目接 ...

  7. 使用easeui dialog弹出框中使用CKeditor多次加载后无法编辑问题

    问题呈现:弹出框页面 <tr class="addtr"> <th>内容</th> <td> <!-- <textare ...

  8. firefox浏览器中 bootstrap 静态弹出框中select下拉框不能弹出(解决方案)

    问题出现场景1: 在firefox浏览器中在bootstrap弹出的modal静态框中再次弹出一个静态框时 select下拉框不能弹出选项 解决方案:去掉最外层静态框的 tabindex=" ...

  9. mvc 在弹出框中实现文件下载

    var myParent = parent.parent.parent.parent.parent.parent.parent.parent.parent.parent.parent.parent; ...

随机推荐

  1. 我认知的javascript之函数调用

    今天刚好周六没事,又由于工作的原因导致早上醒来就睡不着,无聊之下,就想到了 js 的function调用问题.当然,网上也是对javascript的一些事情说得很透了,但我觉得还是有必要把自己的想法说 ...

  2. Think_in_java_4th(并发学习一)

    Java的并发是在顺序语言的基础上提供对线程的支持的. 并发能够更加有效的执行我们的代码,也就是更加合理的应用CPU资源. 并发程序往往CPU和内存使用率,要高于同等的非并发程序. 下面就用Think ...

  3. Bootstrap -- 表格样式、表单布局

    Bootstrap -- 表格样式.表单布局 1. 表格的一些样式 举例: <!DOCTYPE html> <html> <head> <meta http- ...

  4. Linux查询进程和结束进程

    1.  ps -ef |grep redis ps:将某个进程显示出来-A 显示所有程序. -e 此参数的效果和指定"A"参数相同.-f 显示UID,PPIP,C与STIME栏位. ...

  5. 大数据处理框架之Strom:Flume+Kafka+Storm整合

    环境 虚拟机:VMware 10 Linux版本:CentOS-6.5-x86_64 客户端:Xshell4 FTP:Xftp4 jdk1.8 storm-0.9 apache-flume-1.6.0 ...

  6. mongodb安装4.0(rpm)

    虚拟机客户端vmware player linux版本:CentOS Linux release 7.4.1708 (Core) CentOS安装类型:Basic Web Server 参照官网最新文 ...

  7. .NET IL实现对象深拷贝

    对于深拷贝,通常的方法是将对象进行序列化,然后再反序化成为另一个对象.例如在stackoverflow上有这样的解决办法:https://stackoverflow.com/questions/785 ...

  8. hMailServer安装汉化方法

    https://www.hmailserver.org/viewtopic.php?f=5&t=13

  9. Shell命令-文件及内容处理之iconv、dos2unix

    文件及内容处理 - iconv.dos2unix 1. iconv:转换文件的编码格式 iconv命令的功能说明 iconv 命令是 linux 下用于文件转编码的常用命令,对于同时使用 window ...

  10. VMware Workstation 10序列号:

    VMware Workstation 10序列号:1Y0LW-4WJ9N-LZ5G9-Z81QP-92PN7