微信小程序-textarea组件字数实时更新

一、前言

本文实现的是在小程序中,textarea文本框输入文字后,实时显示文字的字数,获取更好的用户输入体验以及提示。

下图是实现的效果
在这里插入图片描述

二、代码实现

2-1、wxml代码

<view style="padding: 30rpx;">
    <view style="font-size: 30rpx; font-weight: 500;">实时字数textArea</view>
    <view class="text-area-box">
        <view class="text-area-len">{{textAreaValue.length}}/{{textAreaMaxLen}}</view>
        <textarea style="height: 100%; width: 100%;" maxlength="{{textAreaMaxLen}}" value="{{textAreaValue}}" bindinput="getInputValue" />
    </view>
</view>

2-2、wxss 代码

.text-area-box {
  position: relative;
  width: 90vw;
  height: 350rpx;
  margin-top: 20rpx;
  background-color: #f1f1f1;
  padding: 14rpx;
  border-radius: 20rpx;
}
.text-area-len {
  width: 150rpx;
  height: 50rpx;
  border-radius: 10rpx;
  font-size: 26rpx;
  background-color: #dbe3f7;
  color: #1552ff;
  position: absolute;
  right: 0rpx;
  top: -60rpx;
  text-align: center;
  line-height: 50rpx;
}

2-3、js代码

Page({
  /**
   * 页面的初始数据
   */
  data: {
    textAreaMaxLen: 500,
    textAreaValue: "",
  },
  getInputValue(res) {
    const value = res.detail.value;
    this.setData({ textAreaValue: value });
  },
});

三、结语

最后来一下常规结语:
实际开发中的其他逻辑就不写了。需要同学们自己去考虑异常情况处理等问题啦。

有任何疑问可以在评论区留下。我每天都会进行回复,私聊不回。(为了刷积分)

以上均是本人开发过程中的一些经验总结与领悟,如果有什么不正确的地方,希望大佬们评论区斧正。

💥最后!!!不管这篇文章对你有没有用,既然都看到最后了。
👍赞一个!!!
🤩当然,顺带收藏就最好了。
😎欢迎转载,原创不易,转载请注明出处✍️。

😊如果你对小程序开发有兴趣或者正在学习小程序开发,可以关注我。每一篇都是原创,每一篇都是干货噢~。

————————————————
版权声明:本文为CSDN博主「super–Yang」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_44702572/article/details/135129782

### 微信小程序 `textarea` 组件默认高度设置 在微信小程序中,`textarea` 组件的高度可以通过 CSS 和属性来控制。对于希望调整 `textarea` 高度的情况,可以采用如下几种方式: #### 使用固定高度 通过设定固定的像素值或者相对单位(如 rpx),可以直接定义 `textarea` 的初始高度。 ```css /* wxss */ .textarea-style { height: 200rpx; } ``` #### 自适应内容高度 如果期望 `textarea` 能够随着输入的内容自动增长,则需利用特定的属性配置以及监听事件实现动态调整。 - **auto-height 属性**:此属性允许 `textarea` 根据其内部文本量的变化来自行改变大小。 ```html <!-- wxml --> <textarea class="textarea-class" auto-height></textarea> ``` - 结合 JavaScript 实现更复杂的逻辑处理,在某些场景下可能还需要额外编写脚本来精确管理高度变化[^1]。 #### 常见问题及解决方案 有时即使设置了上述参数也可能遇到一些意料之外的行为,比如组件未能按照预期展示或交互异常等问题。针对这些问题有以下建议: - 如果发现 `textarea` 显示不正常或是与其他元素重叠,检查是否有其他样式冲突影响布局效果; - 当面对 iOS 设备上可能出现的特殊表现时,考虑使用 `disable-default-padding=true` 来移除系统自带内边距从而获得更好的视觉体验[^3]; 另外需要注意的是,关于 `maxlength` 导致无法继续输入字符的现象并非由高度引起而是因为达到了预设的最大字数限制,可通过适当增大该数值或将之设为 `-1` 解决[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

super--Yang

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

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

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

打赏作者

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

抵扣说明:

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

余额充值