$('input,textarea').on('blur',function(){ window.scroll(0,0); }); $('select').on('change',function(){ window.scroll(0,0); });document.body.addEventListener('focusout', function () {window.scrollTo(0, 0);}) 失去焦点后,重新让滚动条滚动到之前的位置 $("input").blur(fu…
起因 h5的输入框引起键盘导致体验不好,目前就算微信.知乎.百度等产品也没有很好的技术方案实现,尤其底部固定位置的输入框各种方案都用的前提下体验也并没有很好,这个问题也是老大难问题了.目前在准备一套与native协议 来解决这个问题,目前项目中的解决方案还是有值得借鉴的地方的,分享一下 业务场景 固定在h5页面底部的输入框 无论是使用 <input /> 还是 <div contenteditable="true"> </div> 在聚焦事件触发调起…
出现场景:IOS端,在弹出层点击input时调起键盘页面会被顶上去document.body.scrollOffset大于0,收起键盘时scrollOffset不变,造成焦点错位. 注:安卓手机点击时调起键盘不会把页面顶上去,会改变窗口高度变化,收起时不会造成影响. jq处理: $('nput').on('blur', function (event) { if (!(event.relatedTarget && event.relatedTarget.tagName)) document…
前言:微信H5项目,ios端出现了软键盘输完隐藏后页面不会回弹,下方会有一大块留白 最近微信和ios都有版本升级,不知道是哪边升级造成的,但是经过测试,软键盘收起后,再滚动一下页面,下面的留白就会消失.所以只要在输入完毕后模拟一下这个“滚动”的操作,就能解决问题了. 如果是用vue写的: <input type="text" @blur="fixScroll" placeholder="请输入xxx"/> //methods中添加:…
微信里面打开web页面,在ios软键盘收起时,页面键盘位置的内容留白,如下图 这个问题纠结了很久,然后请教了老大(威哥),看到页面老大给出的方案就是代码改变滚动条的位置. 这里就监听键盘收起的事件,来改变滚动条位置. //这里区分系统方法和键盘弹出和收起在前两篇文章有记录 document.body.addEventListener('focusout', this.focusoutFunc); //软键盘收起的事件处理 let _isIOS = -1: export function isIO…
我相信大家平时也会遇到这种问题, 移动端 input 或者 textarea获取光标, 整个页面被顶起来, 键盘收起, 页面不复原的问题 ====>>>>  我这边提供两种解决方案: 1. 针对 vue.js html: <input v-model="workWhere" @blur="changBlur"> js: methods: { changBlur(){ window.scroll(0,0);//失焦后强制让页面归位…
环境:vue+vant 的H5页面 场景:输入框输入信息时,如登录.注册等表单信息 问题:键盘收回后页面底部留白,导致dialog组件按钮位移,视觉上,其中的按钮无法正常工作 解决方案:监听失去焦点时,让页面滚动到顶部 HTML:添加失去焦点事件钩子 <input class="input" placeholder="输入手机号" max="11" min="11" maxlength="11" v-…
前言 最近在做 webapp,遇到了很多移动端兼容的问题,其中一个问题就是:输入框触发 focus 后,键盘弹出,然后遮住了输入框. 然后在Android和IOS上,这个问题的表现形式不一样,而原生键盘和第三方键盘也不一样,但引起的问题都是一样的:输入框被遮住了. 需要的效果 在键盘弹出时,获得焦点的输入框要在可视区域内,效果如下图: 键盘弹出.收起的表现 IOS: 输入框获取焦点,键盘弹出,webview高度不会改变,但webview会往上滚,且最大滚动高度scrollTop为键盘高度. 点击…
加入收起软键盘时让页面回正 uni.pageScrollTo({ scrollTop: 0, duration: 0 });…
ios移动端在双击弹出层的时候会出现页面下移,露出底层页面的现象 解决办法: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> </head> <body> <script> (function() { var agent = navigator.userAgent.toLowerCase()…