NO---22 H5在ios端微信浏览器中,input事件触发后页面不复位的问题

Posted 最愁起名字

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了NO---22 H5在ios端微信浏览器中,input事件触发后页面不复位的问题相关的知识,希望对你有一定的参考价值。

之前在做公众号网页时候在ios微信浏览器遇到一个奇怪的问题,就是input框失去焦点系统键盘收起后,页面还是处于向上滚动的状态,并没有复位成输入之前的状态。你再次点击页面时就已经错位了,目前只发现部分ios在微信浏览器有这个问题,所以只针对ios系统且在微信浏览器上做兼容就可以,这里在网上找到一个初版做了小优化,可以直接复制到一个JS,引用就好

// 兼容部分ios手机input失焦后页面上移问题
(function() {
  let myFunction
  let isWXAndIos = isWeiXinAndIos()
  if (isWXAndIos) { // 既是微信浏览器 又是ios============(因为查到只有在微信环境下,ios手机上才会出现input失去焦点的时候页面被顶起)
    document.body.addEventListener(‘focusin‘, () => { // 软键盘弹起事件
      clearTimeout(myFunction)
    })
    document.body.addEventListener(‘focusout‘, () => { // 软键盘关闭事件
      clearTimeout(myFunction)
      myFunction = setTimeout(function() {
        window.scrollTo({top: 0, left: 0, behavior: ‘smooth‘})// 重点  =======当键盘收起的时候让页面回到原始位置
      }, 200)
    })
  }
})()

function isWeiXinAndIos() {
  // window.navigator.userAgent属性包含了浏览器类型、版本、操作系统类型、浏览器引擎类型等信息,这个属性可以用来判断浏览器类型
  let ua = ‘‘ + window.navigator.userAgent.toLowerCase()
  // 通过正则表达式匹配ua中是否含有MicroMessenger字符串且是IOS系统
  let isWeixin = /MicroMessenger/i.test(ua) // 是在微信浏览器
  let isIos = /(i[^;]+;( U;)? CPU.+Mac OS X/i.test(ua) // 是IOS系统
  return isWeixin && isIos
}

 

以上是关于NO---22 H5在ios端微信浏览器中,input事件触发后页面不复位的问题的主要内容,如果未能解决你的问题,请参考以下文章

移动端微信浏览器和ios页面回弹问题

Taro H5端微信授权链接获取code,回调页面通过this.$router.params获取不到参数

uni-app app端微信登录

移动端微信支付和支付宝支付

移动端微信页面兼容性问题集合

iOS/Android 浏览器(h5)及微信中唤起本地APP