您现在的位置是:网站首页> 编程资料编程资料
Html5页面上如何禁止手机虚拟键盘弹出html5手机键盘弹出收起的处理
2023-10-11
345人已围观
简介 这篇文章主要介绍了Html5页面上如何禁止手机虚拟键盘弹出,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
工作中遇到如下需求,点击输入框弹出自定义弹窗,输入框是input标签:

但是在移动端,input会默认触发手机的虚拟键盘,如何阻止手机虚拟键盘弹起呢?目前我试过有两个方案,一个是给input添加readonly属性,另一个就是在input事件处理方法前面添加一句document.activeElement.blur() 。
readonly
使用readonly方式来阻止虚拟键盘弹出应该是最简单最优雅的方式了。readonly 属性规定输入字段为只读。只读字段是不能修改的。不过,用户仍然可以使用 tab 键切换到该字段,还可以选中或拷贝其文本。
值得一提的是它的取值,只要声明了readonly属性,不管取什么值都可以,比如readonly=""、readonly="readonly"、readonly="abc"都是一样的
优点:简单
缺点:在iOS的Safari中无效(未做更多情况测试)
document.activeElement.blur()
这是个什么玩意儿?document.activeElement是一个Web API接口。MDN上的解释是:它返回当前页面中获得焦点的元素,也就是说,如果此时用户按下了键盘上某个键,会在该元素上触发键盘事件,该属性是只读的。
document.activeElement属性始终会引用DOM中当前获得了焦点的元素。元素获得焦点的方式有用户输入(通常是按Tab键)、在代码中调用focus()方法和页面加载。
它里面有很多方法,在浏览器控制台查看,可以看到有很都方法:

那么document.activeElement.blur()为什么可以阻止虚拟键盘弹出呢?原因是:当你点击input的时候,document.activeElement获得了DOM中被聚焦的元素,也就是你点击的input,而调用.blur()方法,blur我相信大家都知道吧,就是取消聚焦。获得被聚焦的元素然后强制blur以达到没有聚焦的样子、、、感觉绕了。
优点:支持Android、iOS
缺点:需要添加额外的JS代码
这句代码加在什么地方?加入有如下HTML
那么这句JS加在事件处理方法中
$("#datePicker").focus(function(){ document.activeElement.blur(); }); 总结
就当前需求来说,用document.activeElement.blur()确实是在绕弯子,直接使用readonly是最佳方案。但是document.activeElement很强大,可以做很多事。
到此这篇关于Html5页面上如何禁止手机虚拟键盘弹出的文章就介绍到这了,更多相关Html5手机键盘弹出内容请搜索以前的文章或继续浏览下面的相关文章,希望大家以后多多支持!
相关内容
- HTML5 body设置自适应全屏HTML页面自适应宽度的table(表格)html5移动端自适应布局的实现HTML5 textarea高度自适应的两种方案关于html选择框创建占位符的问题
- iframe与window.onload如何使用详解遮罩层 + Iframe实现界面自动显示的示例代码通过iframe监听一个DOM元素大小变化关于解决iframe标签嵌套问题的解决方法iframe跨域的几种常用方法跨域修改iframe页面内容详解iframe在移动端的缩放的示例代码web响应式布局中iframe自适应的方法div被iframe遮住的几种情况及解决方法浅谈Iframe网页内部的导航窗口举例讲解HTML中iframe和frame的区别
- HTML5录音实践总结(Preact)HTML5网页录音和上传到服务器支持PC、Android,支持IOS微信功能html5录音功能实战示例详解HTML5 录音的踩坑之旅
- 详解HTML5.2版本带来的修改html5.2 dialog简介详解
- 100floors电梯 第45层 图文攻略_手机游戏_游戏攻略_
- 百万亚瑟王国服妖精战刷够等级送华恋闪卡活动开启_手机游戏_游戏攻略_
- 大师微博自曝 我叫MT3.2新版本或将下周开启_手机游戏_游戏攻略_
- 我叫MT 魔能的狂欢 无大大姐也能混强敌_手机游戏_游戏攻略_
- 天天酷跑叉叉助手未能成功部署的快速解决方法推荐_手机游戏_游戏攻略_
- 天天酷跑新版本刷钻石攻略 天天酷跑新版本刷钻石方法心得经验分享_手机游戏_游戏攻略_
