[随笔] uniapp踩坑---微信小程序端textarea显示不正常等问题

问题:uni-app 中的 textarea 组件在微信小程序中展示为原生组件,其优先级会大于框架组件如 scroll-view 组件,因此将 textarea组件 放在 scroll-view 组件内会发生穿透弹窗或遮罩层问题,然而 uni 中提供的解决方案:cover-view 组件暂时仅可覆盖的原生组件:video 和 map ,无法覆盖 textarea 组件。
(目前 uni 中cover-view 说明:uniapp 之 cover-view组件)

  • 【[随笔] uniapp踩坑---微信小程序端textarea显示不正常等问题】解决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; }
  • 解决页面滚动时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

    推荐阅读