js 监听手机端键盘弹出和收起事件
//这里区分不同系统,可以参考之前的文档记录 https://www.cnblogs.com/wind-wang/p/10737110.html const ua = typeof window === 'object' ? window.navigator.userAgent : ''; let _isIOS = -1;
let _isAndroid = -1; export function isIOS() {
if (_isIOS === -1) {
_isIOS = /iPhone|iPod|iPad/i.test(ua) ? 1 : 0;
}
return _isIOS === 1;
} export function isAndroid() {
if (_isAndroid === -1) {
_isAndroid = /Android/i.test(ua) ? 1 : 0;
}
return _isAndroid === 1;
}
1、在ios中软键盘弹起时,仅会引起$(‘body’).scrollTop值改变,但是我们可以通过输入框的获取焦点情况来做判断,但也只能在ios中采用这个方案,
因为在android中存在主动收起键盘后,但输入框并没有失焦,而ios中键盘收起后就会失焦;
2、在android中软键盘弹起或收起时,会改变window的高度,因此监听window的onresize事件;
focusin和focusout支持冒泡,对应focus和blur,使用focusin和focusout的原因是focusin和focusout可以冒泡,focus和blur不会冒泡,这样就可以使用事件代理,处理多个输入框存在的情况
if (isAndroid()) {
  const innerHeight = window.innerHeight;
  window.addEventListener('resize', () => {
    const newInnerHeight = window.innerHeight;
    if (innerHeight > newInnerHeight) {
      // 键盘弹出事件处理
      alert("android 键盘弹窗事件");
    } else {
      // 键盘收起事件处理
      alert("android 键盘收起事件处理")
    }
  });
} else if (isIOS()) {
  window.addEventListener('focusin', () => {
    // 键盘弹出事件处理
    alert("iphone 键盘弹出事件处理")
  });
  window.addEventListener('focusout', () => {
    // 键盘收起事件处理
    alert("iphone 键盘收起事件处理")
  });
}
//如果需要移除监听事件可以使用removeEventListener,但如果监听事件中使用的函数是匿名函数,可能移除事件没有任何效果,
可以将监听事件执行的函数,提取出来,使用函数名来指定
例如:
window.addEventListener('focusout', focusoutFunc); function focusoutFunc (){
/*.....*/
} window.removeEventListener('focusout', focusoutFunc); //移除事件
处理完键盘弹出和收起事件后,会发现在ios中键盘收起时,页面内容留白不下滑,滑动下,又恢复正常。android却没有这个问题,后面会介绍处理的方式。
js 监听手机端键盘弹出和收起事件的更多相关文章
- c# 获取移动硬盘信息、监听移动设备的弹出与插入事件
		
原文 http://www.cnblogs.com/coolkiss/p/3328825.html 备忘一下改功能,主要通过WMI来实现,对于监听外接设备的弹出和插入事件一开始使用IntPtr Wnd ...
 - js中对arry数组的各种操作小结  瀑布流AJAX无刷新加载数据列表--当页面滚动到Id时再继续加载数据  web前端url传递值 js加密解密  HTML中让表单input等文本框为只读不可编辑的方法  js监听用户的键盘敲击事件,兼容各大主流浏览器  HTML特殊字符
		
js中对arry数组的各种操作小结 最近工作比较轻松,于是就花时间从头到尾的对js进行了详细的学习和复习,在看书的过程中,发现自己平时在做项目的过程中有很多地方想得不过全面,写的不够合理,所以说啊 ...
 - js监听用户的键盘敲击事件,兼容各大主流浏览器
		
js监听用户的键盘敲击事件,兼容各大主流浏览器 <script type="text/javascript"> document.onkeydown = functio ...
 - js监听input等表单输入框的变化事件oninput
		
js监听input等表单输入框的变化事件oninput,手机页面开发中使用到文本框textarea输入字符监听文本框变化计算还可以输入多少字符,如果使用onkeyup的话是无法监听到输入法输入的文本变 ...
 - js防止安卓手机软键盘弹出挤压页面导致变形的方法
		
5防止安卓手机软键盘弹出挤压页面导致变形的方法 输入框定位在底部,手机端打开,输入框聚焦后软键盘打开为什么会瞬间自动关闭呢? 先看看问题: 1.原来是这样的: 2.在苹果手机里面是正常的: 3.到了安 ...
 - js手机端图片弹出方法
		
1 $("img").click(function(){ //获取窗口可视大小 var width=$(window).width(); var height=$(window). ...
 - Android监听自身卸载,弹出用户反馈调查
		
1,情景分析 在上上篇博客中我写了一下NDK开发实践项目,使用开源的LAME库转码MP3,作为前面几篇基础博客的加深理解使用的,但是这样的项目用处不大,除了练练NDK功底.这篇博客,我将讲述一下一个各 ...
 - Android 应用监听自身卸载,弹出用户反馈调查
		
监听卸载情景和原理分析 1,情景分析 在上上篇博客中我写了一下NDK开发实践项目,使用开源的LAME库转码MP3,作为前面几篇基础博客的加深理解使用的,但是这样的项目用处不大,除了练练NDK功底.这篇 ...
 - html5手机端遮罩弹出菜单代码
		
效果体验:http://hovertree.com/texiao/html5/17/ 效果图: 代码如下: <!doctype html> <html lang="zh&q ...
 
随机推荐
- Git自动化合并多个Commit
			
目录 git rebase逻辑 git editor的修改 处理git-rebase-todo文件 Python实现 当我们有多个commit或者从开源处拿到多个commit时,想合成一个commit ...
 - 我发起了一个 支持 ServerFul 架构 的 .Net 开源项目 ServerFulManager
			
大家好, 我发起了一个 支持 ServerFul 架构 的 .Net 开源项目 ServerFulManager . ServerFulManager 的 目标 是 实现一个 支持 ServerFu ...
 - reset Cisco 2960 password
			
详见:http://www.cahilig.net/2014/04/14/how-reset-cisco-2960-switch-password-without-losing-your-config ...
 - 用于模拟百度分享的errno错误代码
			
0:成功;-1:由于您分享了违反相关法律法规的文件,分享功能已被禁用,之前分享出去的文件不受影响.;-2:用户不存在;请刷新页面后重试;-3:文件不存在;请刷新页面后重试;-4:登录信息有误,请重新登 ...
 - html限制文本框只能输入数字和一个小数点
			
近期在做一个前台页面,有一个文本框是用来输入充值金额的,就想到了限制用户只能输入纯数字的数据且只能包含一个小数点.下面就是我实现的代码 $(function() { //阻止数字键以外的按键输入 $( ...
 - HD,3G视频数据中行号的插入方法---Verilog代码实现
			
HD,3G视频数据中行号的插入方法---Verilog代码实现 行号的生成: `timescale 1ns / 1ps //////////////////////////////////////// ...
 - python基础知识15---三元表达式、列表推导式、生成器表达式、递归、匿名函数、内置函数
			
阅读目录 一 三元表达式.列表推导式.生成器表达式 二 递归与二分法 三 匿名函数 四 内置函数 五 阶段性练习 一. 三元表达式.列表推导式.生成器表达式 1 三元表达式 name=input('姓 ...
 - sudo 取消密码
			
通常我们并不以root身份登录,但是当我们执行某些命令 (command)时需要用到root权限,我们通常都是用"sudo command"来执行command.由于使用Ubunt ...
 - python request Payload 数据处理
			
普通的http的post请求的请求content-type类型是:Content-Type:text/html; charset=UTF-8, 而另外一种形式request payload,其Cont ...
 - 软件推荐----数据库数据处理Navicat Premium
			
一般情况下,企业对数据库的管控很严,通常管控分成以下: 对整台服务器管理权限,如:操作系统Administrator+SA 对单个数据库(Oracle的表空间)完全权限,如:SQL DB_Owner ...