苹果手机iOS11中fixed弹出框中input光标错位问题
最近遇到了一个移动前端的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光标错位问题的更多相关文章
- 在IOS11中position:fixed弹出框中的input出现光标错位的问题
问题出现的背景: 在IOS11中position:fixed弹出框中的input出现光标错位的问题 解决方案 一.设计交互方面最好不要让弹窗中出现input输入框: 二.前端处理此兼容性的方案思路: ...
- IOS中position:fixed弹出框中的input出现光标错位的问题
解决方案是 在弹框出现的时候给body添加fixed <style type="text/css"> body{ position: fixed; width: 100 ...
- JSP中添加弹出框
JSP中添加弹出框 %> <script language="javascript" type="text/javascript"> aler ...
- ckfinder在IE10,IE9中的弹出框不能选择,或者不能上传解决方法
在IE9,或IE10中ckfinder在IE10,IE9中的弹出框不能选择,或者不能上传解决方法 把弹出框嵌入到jquery dialog中.可以解决 I did: // javascript f ...
- 弹出框中选项卡的运用(easyUI)
先看一下页面效果: 此处有两个知识点:一个是弹出框的运用,一个是选项卡的运用 分析一下该HTML代码,最外面一个div是弹出框的,默认是关闭状态,可通过ID来控制弹出框的开关,该div的样式是easy ...
- 弹出框中的AJAX分页
$(function() { $("body").on("click",".set-topic",function(){ /*获取所有题目接 ...
- 使用easeui dialog弹出框中使用CKeditor多次加载后无法编辑问题
问题呈现:弹出框页面 <tr class="addtr"> <th>内容</th> <td> <!-- <textare ...
- firefox浏览器中 bootstrap 静态弹出框中select下拉框不能弹出(解决方案)
问题出现场景1: 在firefox浏览器中在bootstrap弹出的modal静态框中再次弹出一个静态框时 select下拉框不能弹出选项 解决方案:去掉最外层静态框的 tabindex=" ...
- mvc 在弹出框中实现文件下载
var myParent = parent.parent.parent.parent.parent.parent.parent.parent.parent.parent.parent.parent; ...
随机推荐
- windows10禁用更新方法
本方法由本人在无意中发现,实测有效 1.第一步 打开文件管理器路径进入到win10的下载更新文件的目录 C:\Windows\SoftwareDistribution 选中Download文件夹 ...
- python3 OrderedDict类(有序字典)
创建有序字典 import collections dic = collections.OrderedDict() dic['k1'] = 'v1' dic['k2'] = 'v2' dic['k3' ...
- python3 set(集合)
add(增加元素) name = set(['Tom','Lucy','Ben']) name.add('Juny') print(name) #输出:{'Lucy', 'Juny', 'Ben', ...
- U盘中的快捷方式解析
很多人都有使用绿色软件的习惯,在这里我简单称其为Portable App 将这些软甲放到U盘中随身携带,便于我们使用更加符合自身习惯的功能软件. 相信习惯将软件放到U盘启动都会碰到一个问题,就是每次打 ...
- mysql的分组
以下是根据老师的视屏写的总结,要自己实际操作以下. 首先老师一顿操作猛如虎,得到以下的表. 然后进行以下的操作: 发现筛选时报错了,老师的解释实说,分组是因为mysql不知道选择谁而出现报错,因为pa ...
- [P1169] 棋盘制作 &悬线法学习笔记
学习笔记 悬线法 最大子矩阵问题: 在一个给定的矩形中有一些障碍点,找出内部不包含障碍点的,边与整个矩形平行或重合的最大子矩形. 极大子矩型:无法再向外拓展的有效子矩形 最大子矩型:最大的一个有效子矩 ...
- C++笔记--std::相关
std::packaged_task https://www.cnblogs.com/haippy/p/3279565.html https://en.cppreference.com/w/cpp/t ...
- Redis数据结构之简单动态字符串SDS
Redis的底层数据结构非常多,其中包括SDS.ZipList.SkipList.LinkedList.HashTable.Intset等.如果你对Redis的理解还只停留在get.set的水平的话, ...
- PS制作漂亮紫色霓虹灯光文字
一.新建画布,大小1500 * 950像素,分辨率为300,置入墙壁图像,大小适合. 二.调整图层的色阶,色相/饱和度. 三.新建文字图层,颜色为#a33e88,大小为103,字体为Beon Medi ...
- git branch --set-upstream 本地关联远程分支
最近使用git pull的时候多次碰见下面的情况: There is no tracking information for the current branch.Please specify whi ...