zoukankan      html  css  js  c++  java
  • 安卓虚拟键盘挡住input框解决办法

    问题描述:ios弹出虚拟键盘的时候会自动将页面顶上去,不会遮住input输入框,而安卓则会挡住。

    解决办法:

    1.使用如下代码来区分安卓,存入localStorage中

    if ((navigator.userAgent.match(
                    /(Android)/i
                ))) {
                /*你的手机版*/
                localStorage.setItem("noPC", true);
            }
     
    2.判断是安卓端,监听input输入框聚焦事件,input聚焦必定弹出虚拟框,此时给页面加padding-bottom使页面可滚动(因为页面(容器)可滚动时scrollIntoView()才有用!),再使用scrollIntoView()使input框滚动到可视区域,代码如下
    $('input').on("focus", function() {
            if (localStorage.getItem("noPC")) {
                $("#chagePWD").css({
                    "padding-bottom": "400px",
                })
                setTimeout(() => {
                    const activeElement = document.activeElement;
                    activeElement.scrollIntoView(); //焦点元素滚到可视区域
                }, 200);
            }
        });
     
    3.监听input输入框失去焦点事件,虚拟键盘收起,页面恢复原样,代码如下
    $('input').on("blur", function() {
            if (localStorage.getItem("noPC")) {
                $("#chagePWD").css("padding-bottom", "0px")
            }
        });
     
    在各安卓手机和安卓平板上亲测兼容良好
     
     

    scrollIntoView()的解释:

    scrollIntoView是一个与页面(容器)滚动相关的API(官方解释),该API只有boolean类型的参数能得到良好的支持(firefox 36+都支持),所以在这里只讨论参数Boolean类型的情况。

    调用方法为 element.scrollIntoView() 参数默认为true。

    参数为true时调用该函数,页面(或容器)发生滚动,使element的顶部与视图(容器)顶部对齐;

    参数为false时,使element的底部与视图(容器)底部对齐。

    TIPS:页面(容器)可滚动时才有用!

     
  • 相关阅读:
    配置文件和脚本文件区别
    .sh
    瘋耔思维空间
    vi编辑器的三种模式
    在ubuntu系统荣品开发配套JDK安装
    如何查看自己运行ubuntu是32位还是64位
    志气
    高仿微信朋友圈
    Java OCR tesseract 图像智能字符识别技术 Java代码实现
    构建基于Javascript的移动CMS——加入滑动
  • 原文地址:https://www.cnblogs.com/yszblog/p/14931272.html
Copyright © 2011-2022 走看看