vue中使用vant组件出现软键盘顶起页面——导致事件失效

vue中使用vant地址组件页面被顶起问题

遇到问题

  • IOS设备,当前发现有7Plusiphone11【测试机有限,更新版本设备未测】

  • vue页面中使用vant地址组件, 当操作到详细地址时,软键盘顶起页面往上移动。

  • 当软键盘关闭时,页面没有还原。

  • 操作页面点击事件时无效,【因页面移动导致位置不对】

复现效果图

  1. 输入收货人时页面展示正常
  2. 当操作详细地址时会发现,软键盘顶起页面往上移动, 导致事件失效操作不准确

在这里插入图片描述

解决方法

在需要使用页面的created()生命周期中添加以下代码

import { iosInputHandle } from '@/api/commonApi';

created() {
    iosInputHandle();
}
export const iosInputHandle = () => {
    // 判断是否是ios
    var ua = navigator.userAgent;
    if (!!ua.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/)) {
        let flag = false
        let pageBackNormFunc
        document.body.addEventListener('focusin', () => {
            // 软键盘弹起事件
            flag = true
            pageBackNormFunc && clearTimeout(pageBackNormFunc)
        })
        document.body.addEventListener('focusout', () => {
            // 软键盘关闭事件
            if (flag) {
                pageBackNormFunc = setTimeout(function () { 
                    // 当键盘收起的时候让页面回到原始位置
                    window.scrollTo({ top: 0, left: 0, behavior: 'smooth' }) 
                }, 200)
            }
            flag = false
        })
    }
}

感谢大神们

  • 3
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值