扫码枪输入mysql_在react中如何实现扫码枪输入

触发原理

原理就是监听键盘输入,比如扫一个为6970596130126的69条形码,用扫码枪扫一下会在光标位置依次输出:6

9

7

0

5

9

6

1

3

0

2

6

但这不是完整的,所以需要写一个函数scanEvent来整理收集到的每个编号。let code = '';let lastTime,

nextTime,

lastCode,

nextCode;function scanEvent(e, cb) {

nextCode = e.which;

nextTime = new Date().getTime();    if (lastCode != null && lastTime != null && nextTime - lastTime <= 30) {

code += String.fromCharCode(lastCode);

} else if (lastCode != null && lastTime != null && nextTime - lastTime > 100) {

code = '';

}

lastCode = nextCode;

lastTime = nextTime;    if (e.which === 13) {

cb(code);        console.log('code', code);

code = '';

}

}export { scanEvent };

react中的坑

当我们想在willComponentUnMount阶段移除监听器时,需要传递函数名,否则无法移除!!这是非常值得注意的一点。

完整使用class Sample extends React.Component{

componentDidMount(){        window.addEventListener('keypress', this.scanWrapper, false);

}

componentWillUnmount() {        window.removeEventListener('keypress', this.scanWrapper, false);

}

scanWrapper(e) {

scanEvent(e, (code) => {            // to do something...

});

}

}

作者:mytac

链接:https://www.jianshu.com/p/232981dbcddc

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值