当前位置: 首页 > news >正文

uniapp <textarea>组件的踩坑

1、ios真机上,textarea输入时会触发页面其他点击事件,

解决方法:把textarea封装成基础组件,绕过这个bug。

2、使用auto-height属性,安卓真机上,会导致textarea高度异常,
官方人员解释:textarea 的 auto-height 必须要在屏才能计算高度,先展示再赋值。

贴上微信社区的帖子:
https://developers.weixin.qq.com/community/develop/doc/000648f7424528e8f6de0dd4c5fc00

解决办法:把textarea封装成基础组件,dom元素切换时,通过v-if显示隐藏,触发组件onMounted,延迟auto-height赋值。

最后贴上封装的基础组件,供大家参考:

<template><!-- textarea组件 --><textareaclass="input"v-model="inputValue"rows="1":placeholder="placeholder":placeholder-style="placeholderStyle":maxlength="maxlength":disabled="disabled":auto-height="autoHeight"@input="handleInput"/>
</template><script setup>
import { ref, watch, onMounted } from 'vue';
import { getClientPlatform } from '@/utils/clientEnv';/** props-组件属性 */
const props = defineProps({// 值value: {type: String,default: ''},// 提示语placeholder: {type: String,default: '请输入'},// 提示语样式placeholderStyle: {type: String,default: ''},// 最大长度maxlength: {type: String,default: ''},// 是否禁用disabled: {type: Boolean,default: false}
});/** emits-组件事件 */
const emits = defineEmits(['update:value']);let inputValue = ref('');let autoHeight = ref(false);let platform = getClientPlatform();/** 生命周期 */
onMounted(() => {if (platform === 'ios') {console.log('platform=>', 'ios');autoHeight.value = true;} else {console.log('platform=>', 'android');// 安卓真机下,textarea高度会异常,官方人员解释:textarea在屏时,autoHeight属性才能计算高度,进行延迟赋值setTimeout(() => {autoHeight.value = true;}, 10);}
});watch(() => props.value,(newVal) => {inputValue.value = newVal;},{immediate: true}
)// 输入时触发
function handleInput(ev) {const { value } = ev.detail;emits('update:value', value);emits('change', value);
}</script><style lang='scss' scoped>
.input {padding: 0;width: 100%;min-height: 32rpx;height: auto;font-size: 26rpx;color: #333333;text-align: right;
}
</style>
http://www.lryc.cn/news/97326.html

相关文章:

  • README.md 文档使用 treer 生成树形项目结构
  • 朝花夕拾思维导图怎么画?看看这种绘制方法
  • Python - OpenCV、OCR识别摄像头中的文字
  • 金融中的数学:贝叶斯公式
  • ClickHouse单节点安装配置
  • AtcoderABC231场
  • opengauss数据库快速安装
  • 前端中的LocalStorage和SessionStorage
  • 论文工具——写论文好用的绘图工具(甘特图+流程图+网络模型图+泳道图)
  • Vite构建的vue3项目修改网站标题和图标
  • 平安私人银行受邀慈善服务高质量发展会议,分享慈善规划服务
  • MySQL主从复制、读写分离
  • Redis配置与优化
  • leetCode刷题记录3-面试经典150题
  • MySQL优化(面试)
  • 华为鸿蒙HarmonyOS4发布即巅峰,车机系统、多模态交互等实现突破
  • Camtasia2023电脑录屏视频自动生成字幕软件
  • List有值二次转换给其他对象报null
  • 电脑新装系统优化,win10优化,win10美化
  • 实现PC端微信扫码native支付功能
  • MSP432自主开发笔记4:DS3115舵机的0~180全角度驱动
  • 【Matlab】基于卷积神经网络的时间序列预测(Excel可直接替换数据)
  • Ansible安装部署与应用
  • 重生之我要学C++第四天
  • 创建一个简单的 Servlet 项目
  • godot引擎c++源码深度解析系列一
  • 【VB6|第21期】检查SqlServer数据库置疑损坏的小工具(含源码)
  • React的hooks---useCallback useMemo
  • 05. 容器资源管理
  • 通过ETL自动化同步飞书数据到本地数仓