el-input-number出现的点击+-按钮频现不生效

项目中使用到了高德地图,threejs绘制地图,其中有一些数据配置使用到了el-input-number,展示了控件。 操作过程中,点击 +-号,频频不生效

解决过程

1.手动给+icon设置了点击事件,点击生效,没问题

2.change事件未同步icon的点击事件触发,why,为啥没触发呢

看了下el-input-number的源码,没有点击事件,有个v-repeat-click="decrease" 指令

ini 复制代码
 <span
      class="el-input-number__decrease"
      role="button"
      v-if="controls"
      v-repeat-click="decrease"
      :class="{'is-disabled': minDisabled}"
      @keydown.enter="decrease">
      <i :class="`el-icon-${controlsAtRight ? 'arrow-down' : 'minus'}`"></i>
    </span>
    <span
      class="el-input-number__increase"
      role="button"
      v-if="controls"
      v-repeat-click="increase"
      :class="{'is-disabled': maxDisabled}"
      @keydown.enter="increase">
      <i :class="`el-icon-${controlsAtRight ? 'arrow-up' : 'plus'}`"></i>
    </span>

顺藤摸瓜看看指令啥效果,主要就是mousedown 事件,连续加,mouseup清除了定时器,只有这个功能,不应该不生效呀

ini 复制代码
import { once, on } from 'element-ui/src/utils/dom';
import { isMac } from 'element-ui/src/utils/util';

export default {
  bind(el, binding, vnode) {
    let interval = null;
    let startTime;
    const maxIntervals = isMac() ? 100 : 200;
    const handler = () => vnode.context[binding.expression].apply();
    const clear = () => {
      if (Date.now() - startTime < maxIntervals) {
        handler();
      }
      clearInterval(interval);
      interval = null;
    };

    on(el, 'mousedown', (e) => {
      if (e.button !== 0) return;
      startTime = Date.now();
      once(document, 'mouseup', clear);
      clearInterval(interval);
      interval = setInterval(handler, maxIntervals);
    });
  }
};

看页面控制台的verbose 有这个 [Violation] 'requestAnimationFrame' handler took 91ms 原来这个微任务的时间叠加了。

然后重新copy了组件,去掉了这个v-repeat-click="decrease,加一下click函数。向element-ui 提了issue,配置长按累加/减功能,看有没有时间去改

相关推荐
OpenTiny社区4 分钟前
把 SearchBox 塞进项目,搜索转化率怒涨 400%?
前端·vue.js·github
编程猪猪侠33 分钟前
Tailwind CSS 自定义工具类与主题配置指南
前端·css
qhd吴飞37 分钟前
mybatis 差异更新法
java·前端·mybatis
YGY Webgis糕手之路1 小时前
OpenLayers 快速入门(九)Extent 介绍
前端·经验分享·笔记·vue·web
患得患失9491 小时前
【前端】【vueDevTools】使用 vueDevTools 插件并修改默认打开编辑器
前端·编辑器
ReturnTrue8681 小时前
Vue路由状态持久化方案,优雅实现记住表单历史搜索记录!
前端·vue.js
UncleKyrie1 小时前
一个浏览器插件帮你查看Figma设计稿代码图片和转码
前端
遂心_1 小时前
深入解析前后端分离中的 /api 设计:从路由到代理的完整指南
前端·javascript·api
你听得到111 小时前
Flutter - 手搓一个日历组件,集成单日选择、日期范围选择、国际化、农历和节气显示
前端·flutter·架构
风清云淡_A1 小时前
【REACT18.x】CRA+TS+ANTD5.X封装自定义的hooks复用业务功能
前端·react.js