前言:

 并没有完美解决 !

场景:

 最近在做企业微信H5的一个项目,里面有个动态列表页,开始输入框是隐藏的,点击评论才会出现并让 input 聚焦。经过测试在安卓上面应该没什么问题,但是iOS上面会出现 input 被软键盘遮盖或者半遮盖、甚至发送按钮不能点击的状况。

 总的来说问题有点小严重。

查阅百度:

 好的,百度一搜,哇!解决方案很多,我就放心的去抽了一根烟,想着分分钟完事。BUT 经过试验 百度 “ios 下input 被软键盘遮盖” 前两页没有一个能解决我的问题的!!!

 不过收获还是有的... 参考文章如下(写了三个比较可以的吧)

 https://blog.csdn.net/github_37533433/article/details/66471962

 https://juejin.im/post/5b0401b2f265da0b71569ca0

 https://www.cnblogs.com/wx1993/p/6059668.html

解决(Vue):

 因为 iOS 下软键盘弹出并不会改变窗口高度所以也就没试监听 window 的 resize 事件。

 第(n-2)次是在输入框获取焦点的时候:

// 输入框获得焦点
onFocus(){
var that = this;
setTimeout(function(){
that.sendText.scrollIntoView(true);
that.sendText.scrollIntoViewIfNeeded();
},100);
},

 scrollIntoView(true):滚动浏览器窗口或容器元素,以便在当前视窗的可见范围看见当前元素。

 有效果,但是还是会有问题,偶尔还是会出现半遮盖的情况 iPhone6 尤为明显。

 第(n-1)次 是使用的滚动到底部的方法,因为项目的动态列表是有分页的,所以适当的改了一下。

created(){
var u = navigator.userAgent;
this.isAndroid =u.indexOf("Android") > -1 || u.indexOf("Adr") > -1; //Android终端
this.isIOS =!!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/); //IOS终端 },
methods:{
// 输入框获得焦点
onFocus(){
var that = this;
this.bfscrolltop = document.body.scrollTop; // 记录当前位置
if(this.isIOS){
setTimeout(function(){
document.body.scrollTop = document.body.scrollTop*1 + 200;
},300)
} },
},

 在点击发送的时候设置: document.body.scrollTop = this.bfscrolltop;

问题:

 1、在监听失去焦点的时候设置 document.body.scrollTop = this.bfscrolltop 是点不了发送的 (这就触及到我知识的盲区了)

 2、ios 不管型号(可能除了SE)第一次点击评论还是可能会出现半遮盖,或者全遮盖的情况。

 第n次 是在点击评论的时候 加了一个定时器(我不知道为什么这样写就好了!)

created(){
var u = navigator.userAgent;
this.isAndroid =u.indexOf("Android") > -1 || u.indexOf("Adr") > -1; //Android终端
this.isIOS =!!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/); //IOS终端 },
methods:{
// 点击评论
commentClick(index){
var that = this;
if(this.isIOS){
setTimeout(function(){
document.body.scrollTop = document.body.scrollTop*1 + 300;
},300)
}
that.$refs.import_inp.focus();
},
// 输入框获得焦点
onFocus(){
var that = this;
this.bfscrolltop = document.body.scrollTop; // 记录当前位置
if(this.isIOS){
setTimeout(function(){
document.body.scrollTop = document.body.scrollTop*1 + 200;
},300)
} },
// 输入框失去焦点
changeBlur(){
var that = this;
// input 输入框 内无内容的情况下点击ios软键盘的完成是可以回去的
if(this.inputVal == ""){
document.body.scrollTop = this.bfscrolltop;
}
},
// 点击发送
sendComment(){
document.body.scrollTop = this.bfscrolltop;
},
},

 注:以上代码只是关于input输入框被遮盖的。

 目前在 iPhone7 iPhone6 iPhoneSE 上没什么问题

问题:

 1、当输入框内有内容的时候,关掉软键盘是不能返回记录的位置的

总结:

 目前只能解决到这个地步了。黔驴技穷。

 有什么好的解决方案还望看到的朋友指点一二。

 根据自己的项目问题选择一个尽可能最好的方法解决

IOS下 input 被软键盘方案遮盖问题解决的更多相关文章

  1. 移动端踩坑之旅-ios下fixed、软键盘相关问题总结

    最近一个项目掉进了移动端的大坑,包括ios下fixed布局,h5唤起键盘等问题,作为一个B端程序员,弱项就是浏览器的兼容性和移动端的适配(毕竟我们可以要求使用chrome),还好这次让我学习了一下相关 ...

  2. ios safari input fixed 软键盘里的爱恨情仇

    请看第一题: 为什么我的input获取焦点后,被输入法遮住了. 解决办法: 源码: <!DOCTYPE html> <html lang="en"> < ...

  3. ios下input focus弹出软键盘造成fixed元素位置移位

    正常状态下 input focus软键盘弹出时 问题描述: 头部结构fixed,滚动到下部内容区域,input.textarea等focus弹出软键盘时,头部位置偏移被居中(该问题ios7 beta3 ...

  4. 页面的input唤醒软键盘再收起后,页面会出现软键盘高度的空白背景

    微信浏览器在版本6.7.4及以上会有这个bug:页面的input唤醒软键盘再收起后,页面会出现软键盘高度的空白背景,触摸到滚动条会消失恢复! 解决代码 后台框架嵌入iframe的情景,iframe内部 ...

  5. input获取焦点软键盘弹出影响定位

    解决移动端底部fixed和input获取焦点软键盘弹出影响定位的问题$(document).ready(function() {                                var ...

  6. web前端 在 iOS下 input不能输入 以及获取焦点之后会出现蓝色的border轮廓

    iOS下 input 不能获取焦点 获取焦点后:设置border:none无效果 .hb_content input{ display: inline-block; margin-left: 0.22 ...

  7. ios下input获取焦点以及在软键盘的上面

    <!----/此方法基于zepto.min.js--> <!--/div元素没有blur和focus事件,blur focus 只适用于input 这类的表格元素--> < ...

  8. IOS下HTML5获取焦点 弹键盘

    IOS下sifari和webview默认屏蔽textarea/inputbox获取焦点弹出键盘 苹果移动设备的WebView默认屏蔽textarea/inputbox获取焦点弹出键盘,需要在APP页面 ...

  9. ios移动输入框被软键盘遮挡

    页面输入框会出现被软键盘挡住的问题: 解决方法:获取input点击事件设置body高度 $('input').bind('click',function(e){ var $this = $(this) ...

随机推荐

  1. dataTable 参数说明

    下面是一些常用的参数列表,比较常用或者有价值的标示为绿色. 功能参数(Features) 参数名 说明 参考值 默认值 autoWidth 定义是否由控件自动控制列宽 Boolean true def ...

  2. 云计算平台管理的三大利器Nagios、Ganglia和Splunk

    综合利用Nagios.Ganglia和Splunk搭建起的云计算平台监控体系,具备错误报警.性能调优.问题追踪和自动生成运维报表的功能.有了这套系统,就可轻松管理Hadoop/HBase云计算平台. ...

  3. 【转】如何选择Html.RenderPartial和Html.RenderAction

    Html.RenderPartial与Html.RenderAction这两个方法都是用来在界面上嵌入用户控件的. Html.RenderPartial是直接将用户控件嵌入到界面上: <%Htm ...

  4. excel将内容粘贴到筛选后的可见单元格

    默认情况下,筛选后excel表格进行复制粘贴,会贴到隐藏的表格. 可以添加两个辅助列来完成操作:1.在筛选前在表格右边添加"辅助1"列,在第二行输入1,按Ctrl+鼠标左键往下拉到 ...

  5. protocol buffer开发指南

    ProtoBuf 是一套接口描述语言(IDL)和相关工具集(主要是 protoc,基于 C++ 实现),类似 Apache 的 Thrift).用户写好 .proto 描述文件,之后使用 protoc ...

  6. zookeeper集群搭建及Leader选举算法源码解析

    第一章.zookeeper概述 一.zookeeper 简介 zookeeper 是一个开源的分布式应用程序协调服务器,是 Hadoop 的重要组件. zooKeeper 是一个分布式的,开放源码的分 ...

  7. CSS的定位问题总结

    CSS 定位和浮动 CSS 为定位和浮动提供了一些属性,利用这些属性,可以建立列式布局,将布局的一部分与另一部分重叠,还可以完成多年来通常需要使用多个表格才能完成的任务. 定位的基本思想很简单,它允许 ...

  8. [笔记] print函数进阶

      1.1print(values=None,sep='',end='\n',file=sys.stdout,flush=False) 参数: values:输出到控制台的string sep:设置输 ...

  9. VUE脚手架,babel转码 常用命令

    vue-cli脚手架,单页面应用初始化时 npm -v 查看npm版本号 npm install vue-cli -g  全局安装vue-cli vue -V查看vue版本号,说明vue-cli已经安 ...

  10. 破解栅栏密码python脚本

    今天遇到一个要破解的栅栏密码,写了个通用的脚本 #!/usr/bin/env python # -*- coding: gbk -*- # -*- coding: utf_8 -*- # Author ...