移动端H5软键盘的大坑有哪些
这篇文章主要介绍"移动端H5软键盘的大坑有哪些",在日常操作中,相信很多人在移动端H5软键盘的大坑有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"移动端H5软键盘的大坑有哪些"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
1. 部分机型软键盘弹起挡住原来的视图
解决方法:可以通过监听移动端软键盘弹起。
Element.scrollIntoView() 方法让当前的元素滚动到浏览器窗口的可视区域内。参数如下:
true,表示元素的顶部与当前区域的可见部分的顶部对齐
false,表示元素的底部与当前区域的可见部分的尾部对齐
Element.scrollIntoViewIfNeeded()方法也是用来将不在浏览器窗口的可见区域内的元素滚动到浏览器窗口的可见区域。但如果该元素已经在浏览器窗口的可见区域内,则不会发生滚动。此方法是标准的Element.scrollIntoView()方法的专有变体。
window.addEventListener('resize', function() { if (document.activeElement.tagName === 'INPUT' || document.activeElement.tagName === 'TEXTAREA') { window.setTimeout(function() { if ('scrollIntoView' in document.activeElement) { document.activeElement.scrollIntoView(false) } else { document.activeElement.scrollIntoViewIfNeeded(false) } }, 0) } })
2. ios 键盘收起时页面没有回落,底部会留白
部分苹果手机填写表单的时候的,输入内容后关闭软键盘,底部会留一块空白。这种情况可以通过监听键盘回落时间滚动到原来的位置。
window.addEventListener('focusout', function() { window.scrollTo(0, 0) }) //input输入框弹起软键盘的解决方案。 var bfscrolltop = document.body.scrollTop $('input') .focus(function() { documentdocument.body.scrollTop = document.body.scrollHeight //console.log(document.body.scrollTop); }) .blur(function() { document.body.scrollTop = bfscrolltop //console.log(document.body.scrollTop); })
3. onkeyUp 和 onKeydown 兼容性问题
部分 ios 机型 中 input 键盘事件 keyup、keydown、等支持不是很好, 用 input 监听键盘 keyup 事件,在安卓手机浏览器中没有问题,但是在 ios 手机浏览器中用输入法输入之后,并未立刻相应 keyup 事件:
onkeypress 用户按下并放开任何字母数字键时发生。系统按钮(箭头键和功能键)无法得到识别。
onkeyup 用户放开任何先前按下的键盘键时发生。
onkeydown 用户按下任何键盘键(包括系统按钮,如箭头键和功能键)时发生。
4. ios12 输入框难以点击获取焦点,弹不出软键盘
定位找到问题是 fastclick.js 对 ios12 的兼容性,可在 fastclick.js 源码或者 main.js 做以下修改:
FastClick.prototype.focus = function(targetElement) { var length if (deviceIsIOS && targetElement.setSelectionRange && targetElement.type.indexOf('date') !== 0 && targetElement.type !== 'time' && targetElement.type !== 'month') { length = targetElement.value.length targetElement.setSelectionRange(length, length) targetElement.focus() } else { targetElement.focus() } }
5. fastclick 导致下拉框焦点冲突
移动端使用 fastclick 之后,在 ios 环境下,有几个连续的下拉框 第一个 select 框突然填充了第二个下拉框的内容。
根本原因是 Fastclick 导致 ios 下多个 select ,点击某一个,焦点不停变换的 bug。修改源码,在 onTouchStart 事件内判断设备是否为 ios,再判断当前 nodeName 是否为 select,如果是 return false 去阻止 fastClick 执行其他事件。
//line 391行 FastClick.prototype.onTouchStart = function(event) { //在其方法中添加判断 符合ios select的时候 不返回事件 if (deviceIsIOS && this.targetElement == 'select') this.targetElement = null event.preventDefault() } //line521 或者讲源码中 有关touchEnd判断非ios或者非select的事件注释, if (!deviceIsIOS || targetTagName !== 'select') { this.targetElement = null event.preventDefault() }
6. ios 下 fixed 失效的原因
软键盘唤起后,页面的 fixed 元素将失效,变成了 absolute,所以当页面超过一屏且滚动时,失效的 fixed 元素就会跟随滚动了。不仅限于 type=text 的输入框,凡是软键盘(比如时间日期选择、select 选择等等)被唤起,都会遇到同样地问题。
解决方法: 不让页面滚动,而是让主体部分自己滚动,主体部分高度设为 100%,overflow:scroll
.warper { position: absolute; width: 100%; left: 0; right: 0; top: 0; bottom: 0; overflow-y: scroll; -webkit-overflow-scrolling: touch; /* 解决ios滑动不流畅问题 */ } .fix-bottom { position: fixed; bottom: 0; width: 100%; }7. ios 键盘换行变为搜索
input type="search"
input 外面套 form,必须要有 action,action="_javascript:return true"
表单提交阻止默认提交事件
到此,关于"移动端H5软键盘的大坑有哪些"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!
键盘 事件 元素 方法 部分 移动 区域 浏览器 问题 浏览 输入 大坑 页面 学习 底部 手机 源码 焦点 用户 下拉 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 方舟手游服务器地牢进不去 360网络安全周报第246期 群晖dns服务器设置为多少 数据库推荐几本 福建商业软件开发批发价 服务器生成文件夹到d盘 谈谈学习网络安全知识 杭州老夫子网络技术旗下软件 河南工控软件开发价格 网络安全舆情管控表册 广西互联网手优科技 国家工业网络安全标准 力控怎么删除数据库变量 湖南潮流软件开发参考价格 山西思极科技有限公司网络安全 牛总管软件开发公司 数据库管理有发展空间吗 网络安全事业单位面试 网络安全专家李永乐讲课视频 荣耀10小白测评数据库 家用局域网小型服务器 数据库介绍ppt 怀旧服服务器会卡吗 虚拟机服务器逻辑核查看 软件开发如何放入手机 易语言保存DB数据库 杭州r7525服务器行情 山西商业软件开发制造价格 学软件开发的学生笔记本电脑 主宰之剑 服务器