首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

关于H5在移动端弹出下拉选项时遮挡输入框的问题

背景 在最近的一个Hybrid App项目中,我实现的H5有以下两个需求: 使用quill.js实现富文本编辑器,但是,工具栏需要固定定位到底部,当输入法弹出时,工具栏需要悬浮在输入法键盘之上,如下图所示...: 就是一个正常的表单,除了有文本输入,还有下拉选项,当下拉选项弹出时不能遮挡住聚焦的输入框,如下图所示,当点击左图的Complex Labels时,弹出下拉选项,下拉选项遮挡住了Complex Labels...,产品要求的效果是:当下拉选项弹出时不能遮挡住当前聚焦的表单项,也就是Complex labels quill.js工具栏定位问题 工具栏使用的是fixed定位,css如下所示: #ql-toolbar...对于文本输入框之所以不会遮挡,是因为文本输入框进行输入时,弹出的是系统级的输入法键盘,所以不会遮挡。...但是对于下拉选项而言,弹出框的下拉选项是我们自己实现的,也就不是系统级的,所以,系统不会对其进行处理,如:将聚焦的输入框推动到可视范围之内,因此,会导致遮挡问题。

5.4K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【H5】209-可能这些是你想要的H5软键盘兼容方案

    作者最近一段时间在做 H5 聊天项目,过程中踩过一个大坑:输入框获取焦点,软键盘弹起,要求输入框吸附(或顶)在输入法框上。需求很明确,看似很简单,其实不然。...在 IOS 上,使用第三方输入法,高度计算存在偏差,导致在有些输入法弹起,将输入框挡住一部分。 在有些浏览器上使用一些操作技巧,还是存在输入框输入法遮挡。...(比如搜狗输入法),输入框都会被完全挡住;QQ 浏览器或微信浏览器,配合第三方输入法输入框会被遮住一半;百度浏览器配合第三方输入法输入框也会被完全遮住。...; // Android 键盘收起后操作 // 修复小米浏览器下,输入框依旧被输入法遮挡问题 if (judgeDeviceType.isMiuiBrowser) {...; // Android 键盘弹起后操作 // 修复小米浏览器下,输入框依旧被输入法遮挡问题 if (judgeDeviceType.isMiuiBrowser) {

    3.9K12

    可能这些是你想要的H5软键盘兼容方案

    在 IOS 上,使用第三方输入法,高度计算存在偏差,导致在有些输入法弹起,将输入框挡住一部分。 在有些浏览器上使用一些操作技巧,还是存在输入框输入法遮挡。...novalidate="novalidate",novalidate 属性规定当提交表单时不对其进行验证,由于 pattern 校验兼容性不好,可以不让其校验,只让其唤起纯数字键盘,校验工作由 js 去做...(比如搜狗输入法),输入框都会被完全挡住;QQ 浏览器或微信浏览器,配合第三方输入法输入框会被遮住一半;百度浏览器配合第三方输入法输入框也会被完全遮住。...; // Android 键盘收起后操作 // 修复小米浏览器下,输入框依旧被输入法遮挡问题 if (judgeDeviceType.isMiuiBrowser...; // Android 键盘弹起后操作 // 修复小米浏览器下,输入框依旧被输入法遮挡问题 if (judgeDeviceType.isMiuiBrowser

    8.1K20

    iOS学习——键盘弹出遮挡输入框问题解决方案

    UITextField和UITextView,前者是单行输入文本框,后者是可滑动的多行输入文本框,在这整个开发过程中,我们需要控制键盘的弹出和收起、在输入结束的时候获取输入的信息,此外,我们还需要保证在键盘弹起的时候不遮挡我们输入的文本框...今天,我们就主要来说一下文本框输入的完整响应过程以及最后这个遮挡问题的解决方案。...remark = textView.text; [self.submitInfoDic setObject:remark forKey:@"remark"]; } }  四 键盘弹出的遮挡问题...  还是在之前的分析中,我们知道在键盘弹出和收起时,系统都会发出对应的通知,所以我们可以在收到键盘弹出的时候判断键盘的位置和当前输入文本框的位置,如果有遮挡,就将当前视图进行一个向上平移,在收到键盘回收的通知时就平移到原先的位置

    3.6K60

    h5软键盘挡住输入框问题解决(android)

    在部分android机型上测试点击靠下的输入框时遇到弹出的软键盘挡住输入框问题,ios可自身弹起(ios自身的调整偶尔也会出问题,例如第三方键盘会遮挡,原因是第三方输入法的tool bar或者键盘也被当做可视区域...第二种会出现遮挡问题 于是想到以下两种方案: 1.通过动态增加页面高度和设置scrollTop来使输入框到达合适的位置 2.设置相对定位,通过top来使输入框到达合适的位置 影响实现的两个点: 1.js...直接上代码,这里是react项目(css设置absolute配合js改变top实现效果,transition过渡增强用户体验,这里就不放了) getElementOffsetTop(el) {...}) } } 效果基本实现,这里还有两个问题: 第一,如果下面的提交按钮是fixed,有些手机键盘弹出时会把按钮顶上来,如果上述代码中fixHeight设置不合适,会导致这个按钮遮挡输入框...2.两个h5框架,iScroll、Native.js(虽然在这个问题上没啥用) 3.最终奥义:修改设计稿,三招 -> 使输入框不在页面的下半部分、采用分页设计、弹出输入层(ps:要和产品和设计沟通,客户不一定会让步

    6.5K10

    自定义键盘(二)

    一引言 上一篇文章只是自定义了一个键盘的样式,并未和任何的输入框进行关联。只有和输入框进行关联才能是一个有用的键盘。...不知道你有没有注意到应用市场上有这样一类app:第三方输入法app,比如讯飞输入法,搜狗输入法; 第三方输入法app:设置完成之后,手机上所有的输入框都会弹出第三方键盘。...安装第三方输入法的手机,可以在设置–高级设置-语言和输入法中找到。—-系统级别的输入法 那么有没有app级别的输入法扩展呢?...,尽可能让原生属性有效 键盘特殊按钮监听 解决键盘覆盖输入框的问题 点击非键盘,非输入框区域,让键盘消失。...3.7键盘遮挡 这里就需要首先判断是否已经被遮挡,如果被遮挡,需要算出来整个布局需要移动多少,当然键盘布局不能移动。移动方式可以通过属性动画或者scrollBy方法。这里我选择属性动画。

    96420

    Fabric.js 元素被遮挡的部分也可以操作~

    其实 Fabric.js 已经提供了相应的 API 去完成上面的需求了。但直到今天, Fabric.js 官方文档还是那么晦涩难懂,于是就有了本文。...由于 Fabric.js 的默认操作逻辑(前面演示过),在设置 altSelectionKey 的同时最好将 preserveObjectStacking 设置成 true 。...preserveObjectStacking: true, // 默认false altSelectionKey: 'altKey', // 选中元素后,按住alt键,选择被遮挡的部分也能移动当前选中的元素...// 高度 100px }) // 将矩形添加到画布中 canvas.add(circle, rect) } 官方文档的描述对于刚接触 Fabric.js...学 Canvas 相关技术建议动手实践一下~ 代码仓库 ⭐ Fabric.js 元素选中时保持原来层级(按着alt可继续选中)

    1.4K20

    动手写个数字输入框3:痛点——输入法是个魔鬼

    前言  最近在用Polymer封装纯数字的输入框,开发过程中发现不是坑,也有不少值得研究的地方。...本系列打算分4篇来叙述这段可歌可泣的踩坑经历: 《动手写个数字输入框1:input[type=number]的遗憾》 《动手写个数字输入框2:起手式——拦截非法字符》 《动手写个数字输入框3:痛点——输入法是个魔鬼...》 《动手写个数字输入框4:魔鬼在细节——打磨光标位置》 IE的先进性  辛辛苦苦终于控制只能输入数字了,但只要用户启用了输入法就轻松突破我们的重重包围:-<心碎得一地都是。...这是我们会想到底有没有一个API可以禁用输入法呢?答案是有的,但出人意料的是只有IE才支持。...因此我们能做的是 通过keyup事件作事后补救措施; 在keydown中拦截输入法中输入的enter和shift按键事件,然后自行出发keyup事件执行补救措施。 废话少讲,上代码!

    98960
    领券