前端常见兼容问题系列8: 安卓机器中通过JS设置焦点无法拉起软键盘

有时候,为了优化用户体验,做交互设计的同学可能会希望让输入框自动获得焦点并弹出软键盘,这样用户不用点击输入框就可以直接输入。的确,这对用户来说很方便。但真正用HTML5页面去实现的时候,却遇到了问题。

首先我做了这样一个demo。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <meta name="format-detection" content="telephone=no, address=no, email=no, time=no">
    <meta name="viewport" content="width=device-width,user-scalable=no,initial-scale=1.0">
    <title>Title</title>
    <style>
        #input1{
            width: 200px;
            line-height: 30px;
        }
    </style>
</head>
<body>
    <input id="input1" type="text">

    <script>
        document.getElementById('input1').focus();
    </script>
</body>
</html>

在iOS的机器上试验,可以实现需求。但在多台安卓机器上测试时,都发现无法拉起来软键盘。

接着我尝试了给input输入框加上autofocus属性、或者给 document.getElementById('input1').focus();加上延时执行,也都无效。

之后,我又尝试把<input id="input1" type="text">换成一个<div contenteditable="true" id="input1"></div>,再用JS控制它自动获得焦点,事实证明也是无效的。

最后找到一个可以部分解决问题的办法,就是通过一个按钮的click()方法去触发input框的focus()方法。代码清单如下所示:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <meta name="format-detection" content="telephone=no, address=no, email=no, time=no">
    <meta name="viewport" content="width=device-width,user-scalable=no,initial-scale=1.0">
    <title>Title</title>
    <style>
        #input1{
            width: 200px;
            line-height: 20px;
            border: 1px solid #b2b2b2;
            padding: 5px;
        }
    </style>
</head>
<body>
    <input id="input1" type="text">

    <button id="btn">focus</button>

    <script>
        var btn = document.getElementById('btn');

        btn.onclick = function () {
            document.getElementById('input1').focus();
        }
    </script>
</body>
</html>

这个办法可以解决在点击一个按钮,不跳转页面的情况下打开一个弹层,让弹层中的输入框自动获得焦点并拉起软键盘的问题。注意,这里的点击按钮事件是需要手动触发的。如果不手动点击按钮,则即便用JS去触发按钮点击事件,也是不能拉起软键盘的。至于点击按钮后跳转到一个新页面的场景,用这种办法也是无法cover到的。

最后,顺便提一下,有一个方法可以在进入页面时就通过JS拉起软键盘,那就是进入页面时自动执行window.propmt()这个JS语句。遗憾的是,由于window.propmt()弹出的界面不可定制,实在太不美观,因而使用场景非常之有限。

时间: 2024-09-22 05:57:29

前端常见兼容问题系列8: 安卓机器中通过JS设置焦点无法拉起软键盘的相关文章

前端常见兼容问题系列6: 一些安卓APP的WebView中&lt;input type=&quot;file&quot;&gt;不工作

有一次想做一个HTML5的图片上传功能,主要是依赖<input type="file">来选择本地的图片.开始一切都很顺利,在浏览器中,在淘宝等容器中,都能如预期进行文件选择和上传.在iOS系统下的APP中也都工作正常,但是在一个安卓APP中,无论怎么尝试选择文件,都始终出不来. 我给input的onchange事件打了个alert(),点击时也没有任何反应.看来是<input type="file">在这个容器中根本就不工作. 经过一番检索

前端常见兼容问题系列5:¥符号在部分Android APP的WebView中不见了

问题再现 ¥符号在涉及到售卖的页面再常见不过了.但是,测试中居然发现,华为荣耀6 plus(系统4.4.2)上,某APP中该符号不见了,所有用到该符号的地方均成了空白(如图1所示). (图1) 而实际上,我所期望的效果如图2所示: (图2) 分析过程 莫非是编码不对?首先,来看一下我是怎么实现¥这个符号的--用的是CSS,形如 .price:before{ content:'\A5'; display:block; font-size:12px; } 的伪元素. 发现这个问题之后,我尝试把它直接

前端常见兼容问题系列3:永远置于顶层的video

上一篇我们把消失的video找了出来.这一篇我们接着在video上面遮盖一个层,以方便放置一些内容.于是,我们这么做: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="format-detection" content="telephone=no, address=no, email

前端常见兼容问题系列4:sort方法在浏览器中执行效果的差异

前面写了好几个安卓系统下一些手机中的兼容性问题.这次我们来一个iOS系统下的. 有这么一个HTML片段: <body> <p id="container"></p> <div> <script> var str = '' var arr = [ {name: "3", value: "50"}, {name: "2", value: "60"},

前端常见兼容问题系列2:视频哪里去了?

<video>是HTML5中新增的重要标签,用它来引入视频这一生动活波的媒体形式,简单好用,因而这个标签在各种网页中非常常用.但它却并不那么完美. 问题来啦 我们来看一个再简单不过的页面(代码清单如下),主题内容只添加了一个video标签和一个用于做参照物的p标签: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta

安卓开发中intent参数设置的问题?

问题描述 安卓开发中intent参数设置的问题? 比如intent =new intent(), 之后设置了intent.setData(uri),uri是一个xmpp的连接信息:/yangyang%40192.168.0.166%2FandroidN1amkysF,用setresult启动这个intent,不理解这个intent有什么用?没有设置action的话能用吗? 解决方案 intent意图的意思,你可以用它来告诉android需要做的事情,比如启动另外一个activity,携带数据,不

前端常见兼容性问题系列1:丢失的CSS补间动画

[前言] 有人说,前端开发的过程常常就是一个不断"入坑"和"出坑"的.这句话道出了前端开发中的磕磕绊绊以及相伴而来的成长.遗憾的是,这些成长大都只存储在工程师的脑海里,日复一日的,相信总有不少人花掉昂贵的时间在重复解决着同样的"坑". Stack Overflow是我们查找一些常见bug解决办法的好帮手,但我们每天也遇到各式各样的新问题以及有一定独特性的问题.若能花一点精力将自己遇到的问题.思考过程.解决方案.延伸感悟等记录下来,让经验更具延续性

前端常见兼容性问题系列7: 部分浏览器不支持音频自动播放

1.问题又来了 曾做一个活动页,需要打开页面时自动播放一小段背景音乐.因为音乐持续时间非常短,所以设计这个页面时,没想要设置一个播放控制按钮.一开始我也以为确实没有必要.开发中,用我的老古董机器小米2S测了也没发现啥问题. 但是,用iOS机器测试时,问题就来了,有的平台中可以听到背景音乐(如iOS中的支付宝),有的则始终出不来(如iOS 中的Safari浏览器).用JavaScript来load音频,再自动触发音频的play()方法,也没有效果. 2.定位问题.查找原因 Google一番发现原来

安卓手机软键盘-安卓开发怎么获得软键盘高度?

问题描述 安卓开发怎么获得软键盘高度? 如题,不用屏幕高度-activity高度的方法,因为我的activity不能设置成整个布局给软键盘顶起的模式 解决方案 http://www.dewen.io/q/7497http://www.apkbus.com/android-141990-1-1.htmlhttp://www.oschina.net/question/210693_61216?sort=time