微信小程序 解决textarea层级太高导致点击其上方的view它也会获得焦点问题

为了阻止textarea在不必要的时候取得焦点,可将其disabled属性设置为true,在需要的时候再设置为false。下面给出控制disabled和focus的值的方法

wxml:

<view>
    <!--.....具体页面就不贴出来了,在textarea上方会有其他view,目的是实现点击这个view不会使textarea获得焦点-->
    <textarea class='msg' id='message' bindinput='bindinput' disabled='{{disabled}}'
         focus='{{focus}}' catchtap='a' bindblur='b'>
    </textarea>
    <!--..... -->
</view>

js:


Page({
  /**
   * 页面的初始数据
   */
  data: {
    disabled: true,//默认不可用
    focus: false//默认没获取焦点
  },
  bindinput: function (e) {
    var a = e.target.id;
    var value = e.detail.value
    this.setData({
      [a]: value
    })
    return {
      value: value,
      cursor: value.length
    }
  },
  a: function (e) {
    //这里是关键,先设置disabled,再设置focus才能成功实现点击一次获得焦点
    this.setData({
      disabled: false,
    })
    this.setData({
      focus: true
    })
  },
  b: function (e) {
    //失去焦点,将textarea的disabled设置为true
    this.setData({
      disabled: true,
      focus: false
    })
  }
})

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值