当前位置:网站首页>Use of form text box (II) input filtering (synthetic event)
Use of form text box (II) input filtering (synthetic event)
2022-07-05 20:33:00 【Red blue purple】
Use of form text boxes ( Two ) The input filter ( Composite event )
The input filter
Shielding character
scene : The input box needs to limit the characters that appear , For example, it can only be numbers .
The input box itself does not have this function , But we can pass JavaScript To achieve . We can input characters into the input box , Rely on keyboard events , So you can add keyboard events , Then, according to the information of the event object, it is judged that the operator does not meet the conditions , disqualification , Just through event.preventDefault
Block default events , Block input .
<body>
<div class="input-box">
<input type="text" size="10" maxlength="10">
</div>
<script>
const ipt = document.getElementsByTagName('input')[0]
ipt.addEventListener('keypress', (e) => {
console.log(e.key)
if (!/^\d/.test(e.key)) {
e.preventDefault()
}
})
</script>
</body>
The keyboard event we added above is keypress
, because keyup
It is a keyboard lift event , At this time, it has been entered into the input box , It doesn't work ; and keydown
Recognize function keys , Therefore, the function keys must be allowed to pass , Otherwise, there is no way to delete the input . in addition ,keypress
Support case sensitivity .
data:image/s3,"s3://crabby-images/32afc/32afcdf9c103ae50f4888396f45704f39d71574f" alt="filter"
Processing shear plates
We have realized that only numbers can be entered , But if we copy non numeric data from outside , Pasting into the text box will break through our input filter .
data:image/s3,"s3://crabby-images/de87f/de87f18564877b4118c4c4676dfec8ba05c01b30" alt="filter"
At this time, we need to strengthen our input filtering through the clipboard event (HTML5 Added a clipboard event )
copy
: Triggered when a copy operation occurscut
: Triggered when the cut operation occurspaste
: Triggered when the paste operation occurs
These three events are prefixed before
The version is triggered before the operation of , But not often , I don't know any specific use situations . Blocking events can only be blocked in the three events triggered when they occur .
How to get the data of the shear board ? Can pass event
On the object clipboardData
Object to get , To prevent unauthorized access to the clipboard , Can only be accessed during a clipboard event clipboardData
object .
clipboardData
There are 3 A way :getDate
、setData
、clearData
.
const ipt = document.getElementsByTagName('input')[0]
ipt.addEventListener('keypress', (e) => {
console.log(e.key)
if (!/^\d/.test(e.key)) {
e.preventDefault()
}
})
ipt.addEventListener('copy', (e) => {
// e.clipboardData.setData The first parameter is the format , The second parameter is the copied content
e.clipboardData.setData('text/plain', ' Duplicate false data ')
// Mask out default events , Copy fake data
e.preventDefault()
})
ipt.addEventListener('paste', (e) => {
// Read the data of the shear board
const text = e.clipboardData.getData('text/plain')
// Do not paste if the conditions are not met
if (!/^\d/.test(text)) {
e.preventDefault()
}
})
It looks like , Even the pasted data can only be input into the input box if it is a number .
data:image/s3,"s3://crabby-images/77a0c/77a0cb3c1ae8aaee0293c47fda71a9e572ef5309" alt="filter"
Dealing with Chinese 、 Japanese and other input methods
data:image/s3,"s3://crabby-images/102e9/102e9cd62e6c9b98bbbe008db7a3fb075f66542d" alt="filter"
When we use input methods , It will still bypass our limit of only entering numbers .
Here is an interesting knowledge point Composite event
In Chinese, you need to press multiple keys at the same time to input a character . Synthetic events are used to detect and control this input , The input character is in the... Of the event object data
in .
compositionstart
: Indicates that input is about to begin , heredata
For the empty stringcompositionupdate
: Triggered when a new character is inserted , heredata
Characters entered forcompositionend
: Indicates that normal keyboard input is about to be restored , heredata
For the text to be entered into the input box
practice :
const ipt = document.getElementsByTagName('input')[0]
ipt.addEventListener('compositionstart', (e) => {
console.log('%c%s', 'color: red;font-size: 16px;', 'conpositionstart')
console.log(e.data)
})
ipt.addEventListener('compositionupdate', (e) => {
console.log('%c%s', 'color: blue;font-size: 16px;', 'compositionupdate')
console.log(e.data)
})
ipt.addEventListener('compositionend', (e) => {
console.log('%c%s', 'color: purple;font-size: 16px;', 'compositionend')
})
data:image/s3,"s3://crabby-images/63486/6348619b8bfc22906a03fd256e67e7921e1449a6" alt="filter"
So we can at the end of the composite event , namely compositionend
In the event handler of , Remove the input Chinese , It is not allowed to input Chinese characters .
const ipt = document.getElementsByTagName('input')[0]
ipt.addEventListener('compositionend', (e) => {
// Remove the last few digits
e.target.value = e.target.value.slice(0, -e.data.length)
})
data:image/s3,"s3://crabby-images/55750/55750856371479c5867326ee9aac4c5bdeab37ab" alt="filter"
Complete code
<body>
<div class="input-box">
<input type="text" size="10" maxlength="10">
</div>
<script>
const ipt = document.getElementsByTagName('input')[0]
ipt.addEventListener('keypress', (e) => {
console.log(e.key)
if (!/^\d/.test(e.key)) {
e.preventDefault()
}
})
ipt.addEventListener('paste', (e) => {
// Read the data of the shear board
const text = e.clipboardData.getData('text/plain')
// Do not paste if the conditions are not met
if (!/^\d/.test(text)) {
e.preventDefault()
}
})
ipt.addEventListener('compositionend', (e) => {
// Remove the last few digits
e.target.value = e.target.value.slice(0, -e.data.length)
})
</script>
</body>
边栏推荐
- Common view container class components
- 【愚公系列】2022年7月 Go教学课程 004-Go代码注释
- Mongodb basic exercises
- Applet page navigation
- CVPR 2022 | common 3D damage and data enhancement
- Ffplay document [easy to understand]
- Notes on key vocabulary in the English original of the biography of jobs (12) [chapter ten & eleven]
- Guidelines for application of Shenzhen green and low carbon industry support plan in 2023
- Leetcode skimming: binary tree 17 (construct binary tree from middle order and post order traversal sequence)
- Mysql频繁操作出现锁表问题
猜你喜欢
【数字IC验证快速入门】8、数字IC中的典型电路及其对应的Verilog描述方法
Oracle-表空间管理
A solution to PHP's inability to convert strings into JSON
信息学奥赛一本通 1339:【例3-4】求后序遍历 | 洛谷 P1827 [USACO3.4] 美国血统 American Heritage
Convolution free backbone network: Pyramid transformer to improve the accuracy of target detection / segmentation and other tasks (with source code)
Applet event binding
Applet global configuration
CVPR 2022 | common 3D damage and data enhancement
鸿蒙os第四次学习
[quick start to digital IC Verification] 8. Typical circuits in digital ICs and their corresponding Verilog description methods
随机推荐
Rainbond 5.7.1 支持对接多家公有云和集群异常报警
Process file and directory names
Applet page navigation
.Net分布式事务及落地解决方案
Rainbow 5.7.1 supports docking with multiple public clouds and clusters for abnormal alarms
B站UP搭建世界首个纯红石神经网络、基于深度学习动作识别的色情检测、陈天奇《机器学编译MLC》课程进展、AI前沿论文 | ShowMeAI资讯日报 #07.05
USACO3.4 “破锣摇滚”乐队 Raucous Rockers - DP
document方法
【数字IC验证快速入门】1、浅谈数字IC验证,了解专栏内容,明确学习目标
Common view container class components
强化学习-学习笔记4 | Actor-Critic
CVPR 2022 | common 3D damage and data enhancement
Simple understanding of interpolation search
Informatics Olympiad 1338: [example 3-3] hospital setting | Luogu p1364 hospital setting
鸿蒙系统控制LED的实现方法之经典
Leetcode brush question: binary tree 13 (the same tree)
Point cloud file Dat file read save
Is it safe for CICC fortune to open an account online?
DP: tree DP
【愚公系列】2022年7月 Go教学课程 004-Go代码注释