微信小程序一个页面同时存在input和textarea,bindkeyboardheightchange相互影响

html 复制代码
......
<input/>
......
<textarea
    ......
    bindlinechange="textareaLineChange"
    bindinput="onInput"
    bindblur="onBlur"
    bindfocus="onFocus"
    bindconfirm="sendMsg"
    bindkeyboardheightchange="handleKeyboardheightchange"
    ......>
</textarea>

示例代码如上,当一个页面同时存在input和textarea时,(安卓机型)聚焦唤起键盘都会进入textarea的handleKeyboardheightchange事件。

题主希望的效果是,input的任何操作不应该影响到textarea。

经过排查,与查阅相关资料验证,得出结论与下同

textarea与input的相爱相杀

绑定bindkeyboardheightchange事件

问题:

只为textarea绑定bindkeyboardheightchange事件,input也会触发textarea的bindkeyboardheightchange事件,并且触发所携带的参数都是textarea上面的参数

机型:安卓必现

解决总体思路:区分键盘高度触发事件的来源,是input还是textarea

解决方案1:(验证失败)在textarea的focus事件里,增加聚焦标志,当bindkeyboardheightchange触发,判断textarea是否处于聚焦状态,如果不是,则证明该事件来源不是这个textarea

javascript 复制代码
    // textarea聚焦
    const onFocus = e => {
      ......
      isFocus= true
      ......
    }

    // textarea失焦
    const onBlur = e => {
      ......
      isFocus= false
      ......
    }

    // 键盘高度变化监听回调
    const handleKeyboardheightchange = e => {
      if (isFocus) {
        // textarea正在聚焦,可以处理textarea的键盘高度变化
        ctx.triggerEvent('onKeyboardChange', e.detail)
      }
    }

结果失败

失败原因:键盘高度变化事件先于聚焦事件触发(实测,有7~10ms的时间间隔)


解决方案2:(验证失败)在textarea上面绑定data-xxx,用e.target.dataset.id来判断事件来源是不是textarea

javascript 复制代码
......
<input/>
......
<textarea
    ......
    data-id="footer-textarea"
    bindlinechange="textareaLineChange"
    bindinput="onInput"
    bindblur="onBlur"
    bindfocus="onFocus"
    bindconfirm="sendMsg"
    bindkeyboardheightchange="handleKeyboardheightchange"
    ......>
</textarea>



    // 键盘高度变化监听回调
    const handleKeyboardheightchange = e => {
      if (e.target.dataset.id === 'footer-textarea') {
        // 事件来源是textarea,可以处理textarea的键盘高度变化
        ctx.triggerEvent('onKeyboardChange', e.detail)
      }
    }

结果失败

失败原因:input会触发textarea绑定的键盘高度变化事件,且事件来源是textarea。根本无法通过data-id来判断事件来源,因为来源都是textarea。


解决方案3:(成功)给textarea绑定bindtap事件,用bindtap事件来实现方案1的效果

html 复制代码
......
<input/>
......
<textarea
    ......
    bindlinechange="textareaLineChange"
    bindtap="textareaTap"
    bindinput="onInput"
    bindblur="onBlur"
    bindfocus="onFocus"
    bindconfirm="sendMsg"
    bindkeyboardheightchange="handleKeyboardheightchange"
    ......>
</textarea>


    let canDealKeyboard = false // 是否需要处理键盘高度变化事件
    const textareaTap = e => {
      canDealKeyboard = true
    }

    // textarea聚焦
    const onFocus = e => {
      ......
      canDealKeyboard = true
      ......
    }

    // textarea失焦
    const onBlur = e => {
      ......
      canDealKeyboard = false
      ......
    }

    // 键盘高度变化监听回调
    const handleKeyboardheightchange = e => {
      if (canDealKeyboard) {
        // textarea正在聚焦,可以处理textarea的键盘高度变化
        ctx.triggerEvent('onKeyboardChange', e.detail)
      }
    }

结果成功

成功原因:事件触发顺序是 点击事件--键盘变化事件--聚焦事件

点击事件先于键盘变化事件触发,可以在这个节点增加判断标志

相关推荐
趁着年轻吃点苦5 小时前
小程序主包体积优化 - 路径迁移修复实战
小程序
Tancenter5 小时前
支付宝小程序的用户登录/注册流程
小程序·登录·注册·支付宝
微爱帮监所写信寄信5 小时前
微爱帮监狱寄信写信小程序与焦作邮政系统对接技术方案
开发语言·网络协议·小程序·https·php·监狱寄信
狂龙骄子5 小时前
uniapp圆形时钟
小程序·uniapp·canvas·clock·圆盘时钟
微爱帮监所写信寄信6 小时前
微爱帮监狱寄信写信小程序工单系统技术方案:智能投诉处理与问题解决平台
人工智能·网络协议·安全·小程序·内容审核·监狱寄信
GRsln7 小时前
解决微信小程序报“errno“:600001 ERR_CERT_AUTHORITY_INVALID问题
nginx·微信小程序·小程序·ssl
阿奇__7 小时前
配置扫普通二维码进入微信小程序体验版踩坑
微信小程序·小程序
毕设源码-邱学长7 小时前
【开题答辩全过程】以 基于微信小程序的知识问答服务系统为例,包含答辩的问题和答案
微信小程序·小程序
微爱帮监所写信寄信7 小时前
微爱帮监狱写信寄信小程序智慧天气关怀系统技术方案
网络协议·小程序·https·监狱寄信·微爱帮
2501_915921437 小时前
iPhone HTTPS 抓包在真机环境下面临的常见问题
android·ios·小程序·https·uni-app·iphone·webview