处理移动端iframe中input框的一些总结

在移动端项目中,iframe内的input元素出现了一些问题。当点击input时,输入框不会自动定位到键盘上方,针对这种情况,解决方案是通过JavaScript在focus时调整输入框的位置。另外,对于不需要弹出键盘的情况,如日期组件或扫码枪设备,可以通过设置input失焦或在focus时添加移除readonly属性的延迟操作来避免键盘弹出。这些方法在安卓设备上有效,但iOS Safari浏览器暂不支持。
摘要由CSDN通过智能技术生成

最近项目中的移动端使用iframe作为字容器,在处理input遇到一下一些问题。

1、点击input时,input不会自动显示在键盘上方。

解决方法:当focus将输入框呈现在可视位置。

$("iframe").contents().on('focus',"input[type=\"text\"],textarea", function(){
    var target = this;
    setTimeout(function(){
        target.scrollIntoViewIfNeeded();
    },200);
})

2、点击input不想弹出键盘

2.1、在处理一些input时比如日期组件,往往不希望键盘弹出。

解决方法:focus时input失焦

$("iframe").contents().on("focus",".timeInput, .time-input, .date-input, .timeInput",function(){
    document.activeElement.blur();
})
2.2、在自带扫码枪(PDA)的设备上点击输入框不显示键盘

解决方法:
第一步:点击input时先失焦,然后focus。
第二步:当focus时先设置readonly去掉readonly,为了防止键盘弹出过快,使用setTimeout延迟remove readonly。

兼容性:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

kitt15

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

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

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

打赏作者

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

抵扣说明:

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

余额充值