最近遇到了一个移动前端的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. Python基础——3特性

    特性 切片 L=[0,1,2,3,4,5,6,7,8,9,10] L[:3]=[0,1,2] L[-2:]=[9,10] L[1:3]=[1,2] L[::3]=[0,3,6,9] L[:5:2]=[ ...

  2. 第五节 matplotlib库

    一.Matplotlib基础知识 1.1Matplotlib中的基本图表包括的元素 x轴和y轴 axis水平和垂直的轴线 x轴和y轴刻度 tick刻度标示坐标轴的分隔,包括最小刻度和最大刻度 x轴和y ...

  3. 【Teradata UDF】中文按字符查找chs_instr

    一.场景描述 数据库为ASCII编码单字节存储,在查询中文时可能会出现错误结果.例如查询like“房”字,会查询出不含“房”,含“朔科”的结果. select * from Tablename01 w ...

  4. 先vue-cli,再nuxt试试路由

    https://segmentfault.com/a/1190000007933349

  5. Use of Recv-Q and Send-Q

    From my man page: Recv-Q Established: The count of bytes not copied by the user program connected to ...

  6. 不安分的 Go 语言开始入侵 Web 前端领域了!( WebAssembly )

    参考:https://blog.csdn.net/csdnnews/article/details/84038848 从 Go 语言诞生以来,它就开始不断侵蚀 Java .C.C++ 语言的领地.今年 ...

  7. Facebook第三方网页登录(JavaScript SDK)

    文档网址:https://developers.facebook.com/docs/facebook-login/web#logindialog 一.应用配置  https://www.faceboo ...

  8. win10下ElasticSearch5.5.1与head、Kibana、X-Pack、SQL、IK、PINYIN插件的配置安装

    ElasticSearch5.5.1与插件的配置安装 Elasticsearch5.5.1安装: 下载地址https://www.elastic.co/cn/downloads/elasticsear ...

  9. PS调出韩式米黄色室内婚纱照片

    原图: Camera Raw打开原图. 光线调整,压暗白色,保留高光细节,少量对比黑色压暗. 降低整体饱和. 曲线调整,压暗高光明度. 减红加青(融合色彩). 中间调,靠近暗部区域加蓝,靠近亮部区域加 ...

  10. 控制结构(10): 指令序列(opcode)

    // 上一篇:管道(pipeline) // 下一篇:Continuation-passing_style(CPS) 发现问题 在一个正式项目的开发周期中,除了源代码版本控制外,还存在着项目的配置/编 ...