首頁 >web前端 >js教程 >JavaScript實現仿淘寶商品購買數量的增減效果_javascript技巧

JavaScript實現仿淘寶商品購買數量的增減效果_javascript技巧

WBOY
WBOY原創
2016-05-16 15:18:461668瀏覽

近期在開發一個地方O2O租書項目,使用ASP.NET MVC技術,其中在圖書詳情頁,用戶可以輸入借閱的數量,這裡使用了js來控制數量的增減和校驗。

1.數量一定是數字

2.點選增減按鈕的時候要能自動加1或減1

3.使用者輸入的內容如果是非數字,則不能輸入(退格鍵除外)

4.使用者輸入的值最小為1

5.輸入框離開焦點時要檢查取值範圍,確保輸入框中必須是範圍內的數字

基本上就是以上幾點

效果如下:

以下是Html程式碼

<div class="bookNum">
<a id="sub" href="javascript:void(0);">-</a>
<input type="text" value="1" id="bookNum">
<a id="add" href="javascript:void(0);">+</a>
<a href="javascript:void(0);" id="addCart">加入借阅台</a>
<div class="clear"></div>
</div> 

首先看第一條:

輸入一定是數字

這很容易想到用keyup事件監測,用正規表示式取代非數字字元

$("#bookNum").keyup(function(){
var regex = /[^\d]*/g;
var numVal = $(this).val();
numVal = numVal.replace(regex,"");
numVal = parseInt(numVal)||;
numVal = numVal < &#63; : numVal;
$(this).val(numVal);
});

這樣就可以保證用戶輸入的一定是數字了,並且我們中間做了校驗,如果使用parseInt轉換為整數後值是NaN,就讓值為1 ,但是我們會發現一個現象,就是用戶如果想清空裡面的數值輸入20的時候,發現裡面的數值總是會變成1

這是不合理的,而且體驗也不好,在輸入非數字的時候,會先顯示那個字符,然後被替換掉。

再觀察一下當網,京東這些網站,當輸入非數字時,輸入框根本就不會有任何動靜,退格後 還能隨意輸入數字。經研究發現,他們使用了監控鍵盤的方法,攔截輸入。

經過改良後:

$("#bookNum").keypress(function(b) {
var keyCode = b.keyCode &#63; b.keyCode : b.charCode;
if (keyCode != 0 && (keyCode < 48 || keyCode > 57) && keyCode != 8 && keyCode != 37 && keyCode != 39) {
return false;
} else {
return true;
}
})

這樣我們保證了在使用者使用取消回車(0),退格(8),左右箭頭(37 39)和數字時 正常輸入,其他按鍵就統統失效了。這樣就能保證輸入的內容是數字了。

但是還有一個問題,使用者使用退格鍵將內容清空後,使用者沒有輸入的時候,值為空

這就要使用keyup和blur事件來彌補了

$("#bookNum").keypress(function(b) {
var keyCode = b.keyCode &#63; b.keyCode : b.charCode;
if (keyCode != 0 && (keyCode < 48 || keyCode > 57) && keyCode != 8 && keyCode != 37 && keyCode != 39) {
return false;
} else {
return true;
}
}).keyup(function(e) {
var keyCode = e.keyCode ? e.keyCode : e.charCode;
console.log(keyCode);
if (keyCode != 8) {
var numVal = parseInt($("#bookNum").val()) || 0;
numVal = numVal < 1 ? 1 : numVal;
$("#bookNum").val(numVal);
}
}).blur(function() {
var numVal = parseInt($("#bookNum").val()) || 0;
numVal = numVal < 1 ? 1 : numVal;
$("#bookNum").val(numVal);
}); 

這樣就能保證使用者在輸入數字的時候的校驗。

使用按鈕控制就更容易了:

//增加
$("#add").click(function() {
var num = parseInt($("#bookNum").val()) || 0;
$("#bookNum").val(num + 1);
});
//减去
$("#sub").click(function() {
var num = parseInt($("#bookNum").val()) || 0;
num = num - 1;
num = num < 1 &#63; 1 : num;
$("#bookNum").val(num);
}); 

好了,這樣就完美解決使用者輸入了。

當然,這裡僅僅說明了js的控制,裡面還可以加入其它控制,例如最大限制,庫存查詢,伺服器校驗等。這裡就不再贅述。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn