简短记录下最近开发移动端项目碰到的小坑,产品需求做一个售后对话页面,底部固定输入框,和微信对话差不多,但是在ios下,fixed失效,输入框被虚拟键盘挡住,在安卓下是正常的。

尝试过网上说的很多方法,因为每个页面的需求和布局可能不相同,比如我做的需要下拉刷新消息,上拉加载更多,用的是minit-UI来做,所以都没有效果

后面无奈用了两套代码,用

var u = navigator.userAgent, app = navigator.appVersion;
var isiOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/); //ios终端

判断是安卓还是ios,安卓的继续底部用固定定位,  ios底部也用固定定位,只是content内容主体部分用绝对定位

<div :class="isIOS?'input-bottom1':'input-bottom'">
<form style="width:70%;">
<input class="message-input" @focus="iosScrollT" @blur="iosScrollB" type="text" v-model="sendMess" >
</form>
<div class="footer-r" @click="postAdvisory">发送</div>
</div>
<div class="content" v-if="IOSis">
<div :style="mHeight">
<div class="service-list" v-for="(item,index) in infoList">
<div class="service-item" v-if="item.is_admin==1">
<i class="iconfont icon-kefuzixunhui"></i>
<div class="border-left-empty"></div>
<div class="message">{{item.content}}</div>
</div>
<div class="service-item1" v-else>
<div class="message1">{{item.content}}</div>
<div class="border-right-empty"></div>
<img :src="userImg"/>
</div>
</div>
</div>
<div ref="msg_end" style="height:40px;"></div>
</div>
.input-bottom1{
position: fixed;
bottom: 60px;
left: 0px;
width: 100%;
border-top: 1px solid #ccc;
background-color: #fff;
z-index: 9998 !important; display: -webkit-box; /* OLD - iOS 6-, Safari 3.1-6 */
display: -moz-box; /* OLD - Firefox 19- (buggy but mostly works) */
display: -ms-flexbox; /* TWEENER - IE 10 */
display: -webkit-flex; /* NEW - Chrome */
display: flex; /* NEW, Spec - Opera 12.1, Firefox 20+ */
-webkit-box-pack: justify;
-webkit-justify-content: space-between;
justify-content:space-between;
-webkit-box-align: center;
-webkit-align-items: center;
align-items: center;
padding: 10px 0;
background-color:#f5f5f7;
border-top:2px solid #dddddf;/*no*/
}
.content{
position: absolute;
top: 50px;
left: 0px;
right: 0px;
bottom: 50px;
overflow: auto;
-webkit-overflow-scrolling: touch;
}
如此,虚拟键盘没有挡住底部的输入框了,但是输入框聚焦光标的时候还是被挡住了一部分,所以又用了@focus="" @blur=""监听输入框光标,改变bottom值:position: fixed;bottom: 60px;,输入框失焦又改成bottom: 0px;
还有用minit-UI来做下拉刷新消息,上拉加载更多不能兼容,所以ios端只能一次把消息加载完,然后进到页面时,页面自动滑动到最底部,从而可以查看到最新消息,所以就用了.scrollIntoView()
that.$refs.msg_end.scrollIntoView();
但是还有一个问题,点击底部自定义的发送按钮没有用,硬要点完成,把虚拟键盘放下去后,再点发送按钮才能把消息发送出去,所以只能监听输入框光标离开或虚拟键盘的动作
document.body.addEventListener('focusout', () => {
//软键盘收起的事件处理 })

$("#keyword").on('keypress', function(e) { //#keyword为input文本框
var keycode = e.keyCode;
var searchName = $(this).val();
if(keycode == '13') {//13为回车键
       //触发事件

});

监听上面事件就发送消息,通过上面的处理亲测效果还不错,输入框能紧贴

另外这博客写的挺好的,可以参考https://blog.csdn.net/hahahhahahahha123456/article/details/82587621

移动端底部fixed固定定位输入框ios下不兼容的更多相关文章

  1. 移动端— position: fixed;固定定位解决方案

    这里有个关键的东西叫做viewport,你经常在页面的头部里可以见到它: <meta name="viewport" content="width=device-w ...

  2. CSS——fixed 固定定位相对于父容器

    position:fixed 固定定位 用 left top 都是相对于浏览器的. 我今天想给网页做一个固定定位的导航 偶然间发现.可以用margin 相对于父容器定位. 小伙伴们可以试试. 不用le ...

  3. 移动端底部导航固定配合vue-router实现组件切换

    在我们平时练习或者实际项目中也好,我们常常遇到这么一个需求:移动端中的导航并不是在顶部也不是在底部,而是在最底部且是固定的,当我们点击该导航项时会切换到对应的组件.相信对于很多朋友而言,这是一个很简单 ...

  4. position之fixed固定定位、absolute绝对定位和relative相对定位

    什么是层模型? 什么是层布局模型?层布局模型就像是图像软件PhotoShop中非常流行的图层编辑功能一样,每个图层能够精确定位操作,但在网页设计领域,由于网页大小的活动性,层布局没能受到热捧.但是在网 ...

  5. 【CSS3】---层模型position之fixed固定定位、absolute绝对定位和relative相对定位

    什么是层模型? 什么是层布局模型?层布局模型就像是图像软件PhotoShop中非常流行的图层编辑功能一样,每个图层能够精确定位操作,但在网页设计领域,由于网页大小的活动性,层布局没能受到热捧.但是在网 ...

  6. position:fixed固定定位的用法

    一.position:fixed:固定定位 1.实现某个元素在可视窗口的居中位置显示 1)给自身设置宽高: 2)给自身加position:fixed: 3)用margin向左移动自身宽度的一半,向上移 ...

  7. 记一次事件委托在 ios 下的兼容 bug

    项目中碰到的兼容类 bug,记录一二. 页面上有几个同类型的控件,点击它们会触发一些事件,很显然,事件委托优于批量绑定.为了图方便,我将 click 事件绑定到了 document.body 上(绑定 ...

  8. div模拟textarea在ios下不兼容的问题解决

    今天发现一个好东西,赶紧记下来,我在用textarea的时候,想要自适应高度,这样就不会出现滚动条.网上找了很多,都是用div模拟的,但是好扯淡,div模拟的在ios下不能聚焦并且不能输入.真坑... ...

  9. new Date在ios下的兼容bug

    今天发现在ios下new Date("2019-03-06").getTime()返回NaN 原因是ios下不支持“-”必须用"/" 记录备忘 var d = ...

随机推荐

  1. Chinese Mahjong UVA - 11210 (暴力+回溯递归)

    思路:得到输入得到mj[]的各个牌的数量,还差最后一张牌.直接暴力枚举34张牌就可以了. 当假设得到最后一张牌,则得到了的牌看看是不是可以胡,如果可以胡的话,就假设正确.否者假设下一张牌. 关键还是如 ...

  2. 教程一 openwrt路由器入门 远程命令行+文件系统

    如图,拿到一个openwrt路由器我们第一步要远程控制. 这里在买了两块wifi-robots  wifi视频模块. 0首先说下这个WIIF的信息 淘宝购买链接 https://item.taobao ...

  3. 逆向-攻防世界-logmein

    iDA载入程序,shift+F12查看关键字符串,找到双击来到所在地址,进入函数 然后进入主函数, 经过分析,可以得出:输入的字符要等于  经过处理的v7和v8的异或.v8很明显,但是v7是怎么回事呢 ...

  4. Angular CLI 升级 6.0 之后遇到的问题

    Angular CLI 1.7.4 在使用 ng build --prod 会构建失败,而 ng build 是正常的.比较好的解决办法是使用 ng build --prod --extract-li ...

  5. html简单的知识

    分布式版本控制git       pwd查询当前目录 ls ls -la   git config --global user.name xxx   git config --global user. ...

  6. 【C语言】位运算

    编写一个函数getbits,从一个16位的单元中取出某几位(即该几位保留原值,其余位0).函数调用形式为getbits(value,n1,2).----简单题目遇到想不到的问题 c语言位运算经典问题: ...

  7. QQ浏览器、火狐浏览器中页面有点大的问题记录

    做页面时候,发现火狐和腾讯QQ浏览器有个问题,就是会将页面显示的比较大,像点了缩放比例120%似的,事实上缩放比例是100%,很奇怪. 甚至面对这个问题,连腾讯公司主页也会放大,也让我很困惑. 比如: ...

  8. OpenCV4.1.0实践(1) - 环境配置及使用

    Pycharm下虚拟环境配置 1.下载whl文件 下载地址:python extension packages 搜索opencv,根据自己的版本下载,我用的python版本是3.5.2,64位: 2. ...

  9. SqlMapConfig.xml 的配置

    jdbc.properties :数据库连接的配置 jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://192.168.181.135:33 ...

  10. Day 2 上午

    内容提要: 二叉搜索树 二叉堆 区间RMQ问题 二叉搜索树 前置技能本节课可能用到的一些复杂度:O(log n). n/1+n/2+...+n/n=O(n log n) 入门题: 给出N次操作,每次加 ...