`

iOS下的 Fixed + Input 调用键盘的时候fixed无效问题解决方案

阅读更多

做touchweb开发的时候,做头疼的是,电脑上面时候好的,有些手机上面也是好的,个别手机和浏览器出现问题,对于这些,只能慢慢调试,找问题。

今天说一下比较老的IOS的问题,那就是“iOS下的 Fixed + Input 调用键盘的时候fixed无效问题”。

案例如下

<body class="layout-fixed">
    <!-- fixed定位的头部 -->
    <header>

    </header>

    <!-- 可以滚动的区域 -->
    <main>
        <!-- 内容在这里... -->
    </main>

    <!-- fixed定位的底部 -->
    <footer>
        <input type="text" placeholder="Footer..."/>
        <button class="submit">提交</button>
    </footer>
</body>

 

 

header, footer, main {
    display: block;}

header {
    position:fixed;
    height:50px;
    left:0;
    right:0;
    top:0;}

footer {
    position:fixed;
    height:34px;
    left:0;
    right:0;
    bottom:0;}

main {
    margin-top:50px;
    margin-bottom:34px;
    height:2000px}
 

 

然后看起来就是下面这个样子。拖动页面时 header 和 footer 已经定位在了对应的位置,目测没问题了。

enter image description here

但接下来问题就来了!如果底部输入框软键盘被唤起以后,再次滑动页面,就会看到如下图所示:

enter image description here

我们看到 fixed 定位好的元素跟随页面滚动了起来… fixed 属性失效了!

 

这是为什么呢?简单解释下: > 软键盘唤起后,页面的 fixed 元素将失效(即无法浮动,也可以理解为变成了 absolute 定位),所以当页面超过一屏且滚动时,失效的 fixed 元素就会跟随滚动了。

 

这便是 iOS 上 fixed 元素和输入框的 bug 。其中不仅限于 type=text 的输入框,凡是软键盘(比如时间日期选择、select 选择等等)被唤起,都会遇到同样地问题。

虽然 isScroll.js 可以很好的解决 fixed 定位滚动的问题,但是不在万不得已的情况下,我们尽量尝试一下不依赖第三方库的布局方案,以简化实现方式。这里抛砖引玉作为参考。

解决思路

既然在 iOS 下由于软键盘唤出后,页面 fixed 元素会失效,导致跟随页面一起滚动,那么假如——页面不会过长出现滚动,那么即便 fixed 元素失效,也无法跟随页面滚动,也就不会出现上面的问题了。

那么按照这个思路,如果使 fixed 元素的父级不出现滚动,而将原 body 滚动的区域域移到 main 内部,而 header 和 footer 的样式不变,代码如下:

<body class="layout-scroll-fixed">
    <!-- fixed定位的头部 (absolute绝对定位也可以)-->
    <header>

    </header>

    <!-- 可以滚动的区域 -->
    <main>
        <div class="content">
        <!-- 内容在这里... -->
        </div>
    </main>

    <!-- fixed定位的底部 (absolute绝对定位也可以)-->
    <footer>
        <input type="text" placeholder="Footer..."/>
        <button class="submit">提交</button>
    </footer>
</body>
header, footer, main {
    display: block;
}

header {
    position: fixed;//或者absolute
    height: 50px;
    left: 0;
    right: 0;
    top: 0;
}

footer {
    position: fixed;//或者写成absolute
    height: 34px;
    left: 0;
    right: 0;
    bottom: 0;
}

main {
/* main绝对定位,进行内部滚动 */
position: absolute;
top: 50px;
bottom: 34px;
/* 使之可以滚动 */
 overflow-y: scroll;
  /* 增加该属性,可以增加弹性,是滑动更加顺畅 */
  -webkit-overflow-scrolling: touch;   
}

main .content {
    height: 2000px;
}

 

 

 

另外,这里的 header 和 footer 使用的是 fixed 定位,如果考虑到更老一些的 iOS 系统不支持 fixed 元素,完全可以把 fixed 替换成 absolute 。测试后效果是一样的。

按照上面布局,就不会出现问题了!

另外一种方案

这个方案是最近在网上看到的,我没有使用过,但是看到案例是没有问题的,感兴趣的可以去看下,我在前端资源库中已经发布了这个方案。

地址如下:http://resource.haorooms.com/softshow-16-151-1.html

 

 

拓展

一般的原生的系统里面并没有这个bug,但是第三方往往会出现 
解决办法原理是通过给body添加scrollTop,把input的位置挪到最上面就可以了, 
另一种通用方法是使用fixed定位到顶部,是可以解决,但是下面的内容会暴露出来,虽然通过嵌套一层能解决,而且脱离文档流,可能有样式问题,无疑又麻烦了,下面是一种办法解决的demo

<html>
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <title>Examples</title>
    <meta content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0,user-scalable=no" name="viewport">
    <meta name="description" content="">
    <meta name="keywords" content="">
    <link href="" rel="stylesheet">
<style type="text/css">
    *{margin:0px; padding: 0px;}
    body,html{ padding: 5px;}
    .scrollDiv{width: 100%;height: 900px;background: #ccc;font-size: 24px;padding-top: 40px; text-align: center;}
    input{-webkit-appearance: none;width: 100%; display: block;margin:10px auto; border-radius: 0px;font-size: 16px; padding: 12px 10px;box-sizing:border-box;box-shadow: none;border:1px solid #666; }
</style></head>

<body style="">
    <div class="main">
        <div class="scrollDiv">滑到最下面</div>
        <input type="text" placeholder="点击我" id="inp">
    </div>

<script type="text/javascript">

var inp = document.querySelector('#inp'); 
var bodyHeight =  document.body.offsetHeight ; 
inp.onclick = function(ev){
    document.querySelector('body').style.height = '9999px';
    setTimeout(function(){
        document.body.scrollTop = document.documentElement.scrollTop = inp.getBoundingClientRect().top + pageYOffset -5;
    },50);
    window.addEventListener('touchmove',fn,false);
 }

inp.onblur = function(){
    document.querySelector('body').style.height="auto"
    document.querySelector('body').removeAttribute('style')
    window.removeEventListener('touchmove',fn,false)
}
//触摸取消blur
function fn(ev){
    var _target = ev.target || ev.srcElement;  
    if(_target.nodeName != 'INPUT') {inp.blur();}
    ev.preventDefault()
};

</script>
</body>
</html>

 

 

分享到:
评论

相关推荐

    iOS中input框问题

    总的来说,解决iOS设备上`input`框弹出键盘后`fixed`定位失效的问题,关键在于理解和利用CSS的`position: sticky;`以及`-webkit-overflow-scrolling: touch;`属性。通过合理的布局和样式设置,我们可以确保在输入框...

    iOS下Html页面中input获取焦点弹出键盘时挡住input解决方案

    iOS下Html页面中input获取焦点弹出键盘时挡住input解决方案 兼容ios8 ios9 ios 10

    Bluetooth+LE+for+iOS+and+Android

    Unity一个很棒的插件,开发蓝牙,支持Android和IOS多平台。

    解决IOS端微信H5页面软键盘弹起后页面下方留白的问题

    前言:微信H5项目,ios端出现了软键盘输完隐藏后页面不会回弹,下方会有一大块留白 最近微信和ios都有版本升级,不知道是哪边升级造成的,但是经过测试,软键盘收起后,再滚动一下页面,下面的留白就会消失。所以...

    解决iOS下无法触发focus事件的问题

    "解决iOS下无法触发focus事件的问题" 在移动端开发中, focus 事件是一个非常重要的事件,它可以帮助开发者更好地控制用户的输入行为。但是在iOS平台上,触发 focus 事件却是一个非常棘手的问题。本文将为大家分享...

    ios解决fixed定位失效并mintui的loadmore上拉加载

    在iOS设备上,由于Safari浏览器的特殊渲染机制,经常会出现`fixed`定位失效的问题,尤其是在使用`Vue.js`框架构建的web应用中。这个问题主要表现为`fixed`元素不再固定于屏幕某个位置,而是随页面滚动而移动。针对这...

    Android 自定义通讯录(仿Ios反弹效果+模糊搜索+查看手机通讯录+拉伸导航条) 效果图如下:

    Android 自定义通讯录(仿Ios反弹效果+模糊搜索+查看手机通讯录+拉伸导航条) 效果图如下:JContact Android 自定义通讯录(仿Ios反弹效果+模糊搜索+查看手机通讯录+拉伸导航条) 效果图如下: image image image ...

    iOS 软键盘遮挡问题 点击外部隐藏软键盘

    为了解决这个问题,iOS提供了多种方法来处理软键盘的显示和隐藏,以确保用户能够方便地与整个应用界面进行交互。 首先,让我们了解一下软键盘是如何自动弹起的。在iOS中,当用户点击UITextField或UITextView等可...

    iOS 键盘遮挡输入框万能解决方案(多个输入框)

    标题“iOS 键盘遮挡输入框万能解决方案(多个输入框)”针对的就是这个问题,提供了一种解决多个输入框被键盘遮挡的通用方法。描述中提到的“OC 键盘遮挡输入框万能解决方案(多个输入框)”表明这是一个基于...

    iOS xcode -lstdc++.6.0.9 lib包下载

    在Xcode10之前的版本里C/C++动态库里使用的都是libstdc++/libstdc++.6/libstdc++.6.0.9动态链接库 ,而在Xcode10,ios12后,为了更好的解决C++ 11产生的问题,将libstdc++/libstdc++.6/libstdc++.6.0.9移除了,全部...

    解决iframe中fixed失效的问题

    在提供的压缩包文件 "iframe中fixed失效问题" 中,可能包含了具体的代码示例或演示页面,你可以直接打开查看这些案例,以更好地理解和应用上述解决方案。实际操作时,需要根据具体项目需求和限制选择合适的方法,...

    js2swift4ios:iOS+UIWebView+WKWebView+JavaScript调用Swift+重定义iOS Alert

    iOS+UIWebView+WKWebView+JavaScript调用Swift+重定义iOS Alert Main.storyboard--选中UIWebView或者WKWebView的Scene--勾选 Is Initial View Controller,可分别测试UIWebView或者WKWebView中的web页面...

    IOS 解决输入框被键盘遮挡问题

    标题"iOS解决输入框被键盘遮挡问题"直指这一常见痛点,描述指出了解决方案——在键盘弹出时,界面向上移动以确保输入框始终可见。以下将详细阐述如何处理这个问题。 首先,我们需要理解iOS中的键盘管理机制。当用户...

    IOS笔试题+答案

    在iOS笔试中,开发者通常会被要求展示他们如何实现特定功能或者解决实际问题的能力。 在解题过程中,考生需要具备良好的编程习惯,理解苹果的MVC(Model-View-Controller)设计模式,以及遵循苹果的Human Interface...

    ios7隐藏虚拟键盘,解决键盘挡住UITextField问题

    本篇文章将详细探讨如何解决这一问题,主要关注如何在iOS 7中隐藏虚拟键盘以及防止键盘遮挡输入框。 首先,我们需要理解问题的根源。当用户点击UITextField时,系统会自动显示虚拟键盘,以便用户输入文本。然而,...

    详解iOS中position:fixed吸底时的滑动出现抖动的解决方案

    iOS 中 position:fixed 吸底时的滑动出现抖动的解决方案 iOS 中 position:fixed 吸底时的滑动出现抖动是前端开发中常见的问题之一。这个问题的出现主要是由于 native 和 h5 两个原因引起的抖动。native 的抖动是...

    Pro OpenGL ES for iOS 电子书PDF+源码

    Pro OpenGL ES for iOS 电子书PDF+源码

    iOS+FFmpeg+脚本+静态库

    在iOS开发中,FFmpeg是一个非常重要的开源项目,它提供了音视频处理的全面解决方案,包括解码、编码、转换、流媒体等众多功能。本文将详细介绍如何在iOS项目中使用FFmpeg,结合提供的脚本和静态库进行集成。 首先,...

    ios输入框(input)背景色为白色无法去除.pdf

    iOS输入框背景色为白色的解决方案 iOS输入框背景色为白色无法去除的问题是由于iOS高版本的输入框默认背景色为白色,且radius也继承了外面div的样式所致。在iOS中,background的transparent属性是无效的,因此在安卓...

    react-native 解决ios中部分版本不能输入中文

    ### React Native iOS 中文输入问题解析与解决方案 #### 背景介绍 在React Native开发过程中,遇到iOS设备上部分版本无法输入中文的情况时有发生。这类问题往往给开发者带来不小的困扰,尤其是在需要用户进行中文...

Global site tag (gtag.js) - Google Analytics