关于微信浏览器H5 React,Vue工程化项目input无法自动聚焦疑难杂症排查

7 篇文章 0 订阅
1 篇文章 0 订阅

前言

最近使用React开发微信H5搜索框自动聚焦功能,发现路由跳转页面后无法自动聚焦。尝试了各种方法均不生效…后来发型是异步加载组件问题,个人估计是微信浏览器在异步组件加载完成后导致节点失焦。

尝试过的解决方法
  • input 属性 autofocus —— 不生效
  • ref保存组件处罚 ref.curren.focus() —— 不生效
解决方案

完整查看了路由注册引入组件的方式,个人认为是异步加载组件的原因。尝试修改为同步引入组件。yes!成功。具体原因需深入调查,先记录以下踩坑

  • 原路由注册方式 (异步,无法自动聚焦)
{
    path: "/search",
    exact: true,
    component: loadable(() => import('./pages/search')),
    title: '搜索',
 }
  • 修改后路由注册方式(同步,完成聚焦)
import SearchPage from './pages/search'
{
    path: "/search?",
    exact: true,
    component: SearchPage,
    title: '搜索'
  }
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

杨周龙

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值