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


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

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

    案例如下

    <body>
        <!-- fixed定位的头部 -->
        <header>这里是头部</header>
    
        <!-- 可以滚动的区域 -->
        <section>
            <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
        </section>
        <!-- fixed定位的底部 -->
        <footer>
            <input type="text" placeholder="Footer"/>
            <button class="submit">提交</button>
        </footer>
    </body>
    

    对应的样式如下:

    header {
        position: fixed;
        height: 50px;
        line-height:50px;
        left: 0;
        right: 0;
        top: 0;
        background:#f00;
        text-align:center;
        color:#fff;
        font-size:18px;
    }
    footer {
        position: fixed;
        height: 40px;
        left: 0;
        right: 0;
        bottom: 0;
        border-top:1px solid #f00;
        border-bottom:1px solid #f00;
    }
    footer input {
        border:0;
        height:38px;
        float:left;
        padding-left:10px;
        60%;
        font-size:16px;
    }
    footer button {
        background:#f00;
        border:0;
        35%;
        height:40px;
        color:#fff;
        font-size:18px;
        float:right;
    }
    
    section {
        margin-top: 50px;
        margin-bottom: 34px;
    }
    section p{
        line-height:50px;
    }
    

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

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

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

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

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

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

    解决思路

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

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

    <!DOCTYPE html>
    <html lang="en">
    <head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
    <title>Document</title>
    <style>
    body{overflow:hidden;}
    header{position: absolute;/*或者fixed*/height: 50px;line-height:50px;left: 0;right: 0;top: 0;background:#f00;text-align:center;color:#fff;font-size:18px;}
    footer {position: absolute;/*或者fixed*/height: 40px;left: 0;right: 0;bottom: 0;border-top:1px solid #f00;border-bottom:1px solid #f00;}
    footer input{border:0;height:38px;float:left;padding-left:10px;60%;font-size:16px;}
    footer button{background:#f00;border:0;35%;height:40px;color:#fff;font-size:18px;float:right;}
    section{
    /* main绝对定位,进行内部滚动 */
    position: absolute;
    top: 50px;
    bottom: 34px;
    /* 使之可以滚动 */
    overflow-y: scroll;
      /* 增加该属性,可以增加弹性,是滑动更加顺畅 */
    -webkit-overflow-scrolling: touch;  
    98% 
    }
    .content p{line-height:50px;}
    </style>
    </head>
    <body>
        <!-- absolute定位的头部 (fixed绝对定位也可以)-->
        <header>这里是头部</header>
        <!-- 可以滚动的区域 -->
        <section>
            <div class="content">
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
    	        <p>这里是内容区域</p>
            </div>
        </section>
        <!-- absolute定位的底部 (fixed绝对定位也可以)-->
        <footer>
            <input type="text" placeholder="Footer"/>
            <button class="submit">立即投资</button>
        </footer>
    </body>
    </html>
    

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

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

    本文出自:http://www.haorooms.com/post/ios_fixed_input

  • 相关阅读:
    UOJ309 UNR #2 排兵布阵
    BZOJ4860: [Beijing2017]树的难题
    CQOI2017 部分题解
    SDOI2017 Round1 Day2 题解
    记SCOI2017
    BZOJ3810: [Coci2015]Stanovi
    BZOJ4785: [Zjoi2017]树状数组
    「ZJOI2007」「LuoguP1169」棋盘制作(并查集
    「LuoguP4147」 玉蟾宫(并查集
    「LuoguP1402」 酒店之王(最大流
  • 原文地址:https://www.cnblogs.com/tnnyang/p/5226814.html
Copyright © 2020-2023  润新知