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

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

有时候,为了优化用户体验,做交互设计的同学可能会希望让输入框自动获得焦点并弹出软键盘,这样用户不用点击输入框就可以直接输入。的确,这对用户来说很方便。但真正用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()弹出的界面不可定制,实在太不美观,因而使用场景非常之有限。

目录
相关文章
|
5天前
|
前端开发 机器人 API
前端大模型入门(一):用 js+langchain 构建基于 LLM 的应用
本文介绍了大语言模型(LLM)的HTTP API流式调用机制及其在前端的实现方法。通过流式调用,服务器可以逐步发送生成的文本内容,前端则实时处理并展示这些数据块,从而提升用户体验和实时性。文章详细讲解了如何使用`fetch`发起流式请求、处理响应流数据、逐步更新界面、处理中断和错误,以及优化用户交互。流式调用特别适用于聊天机器人、搜索建议等应用场景,能够显著减少用户的等待时间,增强交互性。
|
16天前
|
存储 JavaScript 前端开发
前端技术分享:使用Vue.js与Vuex管理状态
【10月更文挑战第1天】前端技术分享:使用Vue.js与Vuex管理状态
38 6
|
16天前
|
JavaScript 前端开发 开发者
前端技术分享:Vue.js 中的自定义指令
【10月更文挑战第1天】前端技术分享:Vue.js 中的自定义指令
46 5
|
5天前
|
JavaScript 前端开发 程序员
前端学习笔记——node.js
前端学习笔记——node.js
17 0
|
6天前
|
JavaScript 前端开发 API
Vue.js:现代前端开发的强大框架
【10月更文挑战第11天】Vue.js:现代前端开发的强大框架
58 41
|
8天前
|
JavaScript 前端开发 API
Vue.js:打造高效前端应用的最佳选择
【10月更文挑战第9天】Vue.js:打造高效前端应用的最佳选择
11 2
|
8天前
|
JavaScript 前端开发 开发者
前端开发趋势:从Web Components到Vue.js
【10月更文挑战第9天】前端开发趋势:从Web Components到Vue.js
|
8天前
|
XML 前端开发 JavaScript
前端开发进阶:从HTML到React.js
【10月更文挑战第9天】前端开发进阶:从HTML到React.js
|
8天前
|
存储 JavaScript 前端开发
前端开发:Vue.js入门与实战
【10月更文挑战第9天】前端开发:Vue.js入门与实战
|
5天前
|
JavaScript 前端开发 应用服务中间件
vue前端开发中,通过vue.config.js配置和nginx配置,实现多个入口文件的实现方法
vue前端开发中,通过vue.config.js配置和nginx配置,实现多个入口文件的实现方法
38 0