基于jquery實(shí)現(xiàn)的銀行卡號(hào)每隔4位自動(dòng)插入空格的實(shí)現(xiàn)代碼
難點(diǎn)不是插入空格,而是修正光標(biāo)的位置,這個(gè)只支持IE9+、chrome瀏覽器
注意:這個(gè)使用了jquery框架
核心代碼
$(function() {
$('#kahao').on('keyup', function(e) {
//只對(duì)輸入數(shù)字時(shí)進(jìn)行處理
if((e.which >= 48 && e.which <= 57) ||
(e.which >= 96 && e.which <= 105 )){
//獲取當(dāng)前光標(biāo)的位置
var caret = this.selectionStart
//獲取當(dāng)前的value
var value = this.value
//從左邊沿到坐標(biāo)之間的空格數(shù)
var sp = (value.slice(0, caret).match(/\s/g) || []).length
//去掉所有空格
var nospace = value.replace(/\s/g, '')
//重新插入空格
var curVal = this.value = nospace.replace(/(\d{4})/g, "$1 ").trim()
//從左邊沿到原坐標(biāo)之間的空格數(shù)
var curSp = (curVal.slice(0, caret).match(/\s/g) || []).length
//修正光標(biāo)位置
this.selectionEnd = this.selectionStart = caret + curSp - sp
}
})
})
完整代碼:已經(jīng)測(cè)試
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title>銀行卡號(hào)4位空格</title>
<script src="http://j2.58cdn.com.cn/js/jquery-1.8.3.js"></script>
</head>
<body>
<input type="text" id="kahao" />
<script>
$(function() {
$('#kahao').on('keyup', function(e) {
//只對(duì)輸入數(shù)字時(shí)進(jìn)行處理
if((e.which >= 48 && e.which <= 57) ||
(e.which >= 96 && e.which <= 105 )){
//獲取當(dāng)前光標(biāo)的位置
var caret = this.selectionStart
//獲取當(dāng)前的value
var value = this.value
//從左邊沿到坐標(biāo)之間的空格數(shù)
var sp = (value.slice(0, caret).match(/\s/g) || []).length
//去掉所有空格
var nospace = value.replace(/\s/g, '')
//重新插入空格
var curVal = this.value = nospace.replace(/(\d{4})/g, "$1 ").trim()
//從左邊沿到原坐標(biāo)之間的空格數(shù)
var curSp = (curVal.slice(0, caret).match(/\s/g) || []).length
//修正光標(biāo)位置
this.selectionEnd = this.selectionStart = caret + curSp - sp
}
})
})
</script>
</body>
</html>
經(jīng)過(guò)測(cè)試確實(shí)很好用,里面用到了很多的正則
\s 匹配任何空白字符,包括空格、制表符、換頁(yè)符等等。等價(jià)于[ \f\n\r\t\v]。
關(guān)于正則表達(dá)式的教程可以參考這篇文章:
http://www.dhdzp.com/tools/zhengze.html
http://www.dhdzp.com/tools/regexsc.htm
相關(guān)文章
jQuery插件EasyUI獲取當(dāng)前Tab中iframe窗體對(duì)象的方法
這篇文章主要介紹了jQuery插件EasyUI獲取當(dāng)前Tab中iframe窗體對(duì)象的方法,涉及EasyUI窗體操作的相關(guān)技巧,需要的朋友可以參考下2016-08-08
Jquery 插件學(xué)習(xí)實(shí)例1 插件制作說(shuō)明與tableUI優(yōu)化
Jquery 插件學(xué)習(xí)實(shí)例1 插件制作說(shuō)明與tableUI優(yōu)化,需要的朋友可以參考下。2010-04-04
autoIMG 基于jquery的圖片自適應(yīng)插件代碼
為了防止圖片撐破布局,最常見(jiàn)的仍然是通過(guò)onload后獲取圖片尺寸再進(jìn)行調(diào)整,所以加載過(guò)程中仍然會(huì)撐破。2011-03-03
jquery實(shí)現(xiàn)初次打開(kāi)有動(dòng)畫(huà)效果的網(wǎng)頁(yè)TAB切換代碼
這篇文章主要介紹了jquery實(shí)現(xiàn)初次打開(kāi)有動(dòng)畫(huà)效果的網(wǎng)頁(yè)TAB切換代碼,涉及jquery通過(guò)鼠標(biāo)click事件控制頁(yè)面元素屬性的動(dòng)態(tài)變換實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-09-09
基于jQuery的360圖片展示實(shí)現(xiàn)代碼
基于jQuery的360圖片展示實(shí)現(xiàn)代碼,需要的朋友可以參考下2012-06-06
jQuery插件實(shí)現(xiàn)大圖全屏圖片相冊(cè)
這篇文章主要介紹了jQuery插件實(shí)現(xiàn)大圖全屏圖片相冊(cè)的方法和示例,基于jQuery插件jQuery.album.js來(lái)實(shí)現(xiàn)的,效果非常不錯(cuò),這里推薦給大家,希望大家能夠喜歡。2015-03-03

