ProFormList实现扫码枪输入

业务需求是需要使用扫码枪连续扫描,而且不允许手动输入,不允��直接粘贴。该需求前期已经通过antd的ProFormList实现了手动输入的操作。

1. 使用组件代码

使用组件如下:

js 复制代码
          <ProForm form={form}>
            <ProFormList
              name="seriesNoList"
              initialValue={[{seriesNo: ""}]}
              actionRef={actionRef}
            >
              { 
                (meta, index, action, count) => {
                  return (
                    <ProFormText 
                        onChange={(e) => {} 
                        name="seriesNo" 
                        label="扫描商品编号" 
                        placeholder="只能使用扫码枪" 
                     />
                  )
                }
              }
            </ProFormList>
          </ProForm>

2. 实现限制手动粘贴

第一反应在ProFormText中监听onPaste事件。但是直接提示该组件没有该属性。然后往上找,ProFormList上监听该事件是可以的。另外,继续往上找,ProForm上也有该事件。所以在这两个组件上监听该事件都可以。

js 复制代码
            onPaste={(e) => {
              e.preventDefault();
              message.warning("不允许粘贴");
            }}

3. 实现限制手动输入

通过onchange事件打印log可以知道,扫码枪的原理就是超快速的输入,并且最后输入一个keyCode == 13。其两个字符之间的时间间隔一般小于10ms。为了保险起见,临界值设成60。

js 复制代码
             {
                (meta, index, action, count) => {
                  const arr = []; // 每个输入框一个记录数组
                  return (
                    <ProFormText 
                      onChange={(e) => {
                        if (arr.length < 2) {
                          arr.push(e.timeStamp);
                          return;
                        }
                        if (arr[1] - arr[0] > 60) {
                          Modal.warn({
                            content: "只允许扫码枪输入",
                            afterClose: () => {
                              action.setCurrentRowData({seriesNo: ""})
                            }
                          });
                          arr.length = 0;
                        }
                      }} 
                      name="seriesNo" label="扫描商品编号" placeholder="只能使用扫码枪" />
                  )
                }
              }

4. 实现扫码后自动新增聚焦

1. 实现自动新增

根据官方文档,自动新增有两种实现方式:

  1. 通过调用方法
js 复制代码
actionRef.current?.add({
            seriesNo: '新增' + list?.length,
          });
  1. 手动点击最下方的新增按钮

因为想使用后续的onAfterAdd事件,但是方法1不会触发该事件。所以只能通过手动触发。而自动新增需要监听到扫码枪的回车输入。即在ProFormList中监听onKeyDown事件,然后手动触发新增事件。

js 复制代码
              onKeyDown={(e) => {
                if (e.keyCode === 13) {
                  e.preventDefault();
                  document.querySelector(".ant-pro-form-list-creator-button-bottom").click();
                }
              }}

2. 实现新输入框自动聚焦

因为要定位当前输入框是第几行,所以需要ProFormList的onAfterAdd事件。因为该事件参数如下:

  • defaultValue
  • index
  • count

其中index表示输入框的位置。然后手动实现聚焦。又因为立即去取最新的输入框dom取不到,所以通过setTimeout去取。

js 复制代码
              onAfterAdd={(text, index, count) => {
                setTimeout(() => {
                  document.querySelector("#seriesNoList" + index + "seriesNo")?.focus(); 
                })
              }}
相关推荐
负责的蛋挞15 分钟前
异步HttpModule的实现方式
java·服务器·前端
丹宇码农3 小时前
把 HLS 字幕玩出花:zwPlayer 如何让 M3U8 视频支持全文搜索、翻译与码率自适应
前端·javascript·音视频·hls·视频播放器
2501_943782353 小时前
【共创季稿事节】猜数字游戏:二分法思维与交互式反馈
前端·游戏·microsoft·harmonyos·鸿蒙·鸿蒙系统
GV191rLvq3 小时前
基于Socket实现的最简单的Web服务器【ASP.NET原理分析】
服务器·前端·asp.net
吠品3 小时前
LangChain 里 tool_call_id 为空?一次 MCP 工具集成的排查记录
前端
微信开发api-视频号协议4 小时前
企业微信二次开发中的文件系统设计:媒体资源、临时文件与业务附件
前端·微信·企业微信·媒体·ipad·微信开放平台
柒和远方4 小时前
Phase 7.4 学习博客:为什么多 API 项目需要 Swagger / OpenAPI
前端·后端·架构
张龙6874 小时前
拼多多开放平台对接踩坑实录:从 CLIENT_ID 配置到 MD5 签名算法的完整填坑指南
前端
GuWenyue4 小时前
提示词彻底过时?一套上下文工程方案,3步让LLM落地生产,代码直接复用
前端·javascript·人工智能