[随笔] uniapp踩坑---微信小程序端textarea显示不正常等问题
问题:uni-app 中的 textarea 组件在微信小程序中展示为原生组件,其优先级会大于框架组件如 scroll-view 组件,因此将 textarea组件 放在 scroll-view 组件内会发生穿透弹窗或遮罩层问题,然而 uni 中提供的解决方案:cover-view 组件暂时仅可覆盖的原生组件:video和 map ,无法覆盖 textarea组件。解决textarea组件为原生组
问题:uni-app 中的 textarea 组件在微信小程序中展示为原生组件,其优先级会大于框架组件如 scroll-view 组件,因此将 textarea组件 放在 scroll-view 组件内会发生穿透弹窗或遮罩层问题,然而 uni 中提供的解决方案:cover-view 组件暂时仅可覆盖的原生组件:video 和 map ,无法覆盖 textarea 组件。
(目前 uni 中cover-view 说明:uniapp 之 cover-view组件)
-
解决textarea组件为原生组件层级最高,穿透弹窗或遮罩层的问题。
此处的解决思路是设置一个跟textarea布局一致的替代元素,与textarea交替展现。当点击替代元素时textarea展现,就可以输入内容,当textarea失去焦点时替代元素展现,将输入值赋给替代元素,这样不输入内容页面滚动时就不会出现textarea穿透问题。本坑注意要设置textarea自动聚焦(focus=“true”—否则要点两次替代元素才能拉起键盘),且两个元素的切换要用 if,不能用显示和隐藏的show- 拓展问题1 自动获取焦点属性不生效,仍需要点击两次
-解决:考虑修改写法为(:focus=“true”),没有冒号将 true 识别为字符串… - 拓展问题2 切换到 view组件 中展示有问题—不换行,但textarea中展示会换行
-解决:给 view组件 添加自动换行样式:{ word-wrap: break-word;word-break: normal;overflow-y:auto; }
- 拓展问题1 自动获取焦点属性不生效,仍需要点击两次
-
解决页面滚动时placeholder/输入内容不随textarea组件滚动问题
经多方尝试,出现这种情况是textarea的某个父级元素设置了overflow属性,去掉所有父级元素的overflow属性即可解决。 -
解决ios上输入法弹起后换行输入内容遮挡,删除输入内容时内容被遮挡问题
要给textarea的父级元素加个margin-bottom,具体多少视情况而定(反正不够就一直加呗),在点击替代元素后先给textarea的父级元素加个margin-bottom,然后将页面滚动到底部,最后再展现textarea并拉起输入法键盘。
转载:
https://blog.csdn.net/RubyLinT/article/details/100975515
来源(详细说明):
https://www.cnblogs.com/growupup/p/9799507.html
更多推荐
所有评论(0)