ホームページ ウェブフロントエンド jsチュートリアル JavaScriptは淘宝網模倣品の購入数量を増減する効果を実装します_JavaScriptスキル

JavaScriptは淘宝網模倣品の購入数量を増減する効果を実装します_JavaScriptスキル

May 16, 2016 pm 03:18 PM

最近、ASP.NET MVC テクノロジーを使用して、ユーザーが借りた数量を入力できるローカル O2O 書籍レンタル プロジェクトを開発しています。ここでは、数量の増減と確認を制御するために JS が使用されています。 。

1. 数量は数値である必要があります

2. 増加または減少ボタンをクリックすると、自動的に 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> 
ログイン後にコピー

まず最初の項目を見てください:

入力は数値である必要があります

キーアップイベント監視を使用し、数値以外の文字を正規表現に置き換えることは簡単に考えられます

$("#bookNum").keyup(function(){
var regex = /[^\d]*/g;
var numVal = $(this).val();
numVal = numVal.replace(regex,"");
numVal = parseInt(numVal)||;
numVal = numVal < ? : numVal;
$(this).val(numVal);
});
ログイン後にコピー

このようにして、ユーザー入力が数値であることを確認し、parseInt を使用して整数に変換した後に値が NaN である場合は、値を 1 にします。ただし、ユーザーが中の値をクリアしたいときに20を入力すると、中の値が必ず1に変わってしまう現象

これは不合理であり、数字以外を入力すると、その文字が最初に表示され、その後置き換えられます。

Dangdang や JD.com などの Web サイトを参照してください。数字以外を入力する場合、バックスペースを押しても入力ボックスはまったく動きません。調査の結果、キーボードを監視する方法を使用して入力を傍受していたことが判明しました。

改善後:

$("#bookNum").keypress(function(b) {
var keyCode = b.keyCode ? b.keyCode : b.charCode;
if (keyCode != 0 && (keyCode < 48 || keyCode > 57) && keyCode != 8 && keyCode != 37 && keyCode != 39) {
return false;
} else {
return true;
}
})
ログイン後にコピー

このようにして、ユーザーが Enter (0)、Backspace (8)、左右の矢印 (37 39) および数字をキャンセルすると、通常どおり入力できるようになり、他のすべてのキーが無効になることが保証されます。これにより、入力内容が数値であることが保証されます。

しかし、ユーザーが Backspace キーを使用してコンテンツをクリアした後、何も入力しないと値が空になります

これは、キーアップ イベントとブラー イベントを使用して補正する必要があります

$("#bookNum").keypress(function(b) {
var keyCode = b.keyCode ? 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 &lt; 1 &#63; 1 : num;
$("#bookNum").val(num);
}); 
ログイン後にコピー

わかりました。これでユーザー入力の問題は完全に解決されました。

もちろん、これは JS コントロールについてのみ説明しており、最大制限、インベントリ クエリ、サーバー検証などの他のコントロールも追加できます。ここでは詳細には触れません。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

JavaScriptの文字列文字を交換します JavaScriptの文字列文字を交換します Mar 11, 2025 am 12:07 AM

JavaScriptの文字列文字を交換します

jQueryは要素のパディング/マージンを取得します jQueryは要素のパディング/マージンを取得します Mar 01, 2025 am 08:53 AM

jQueryは要素のパディング/マージンを取得します

jQuery日付が有効かどうかを確認します jQuery日付が有効かどうかを確認します Mar 01, 2025 am 08:51 AM

jQuery日付が有効かどうかを確認します

10 jQuery Accordionsタブ 10 jQuery Accordionsタブ Mar 01, 2025 am 01:34 AM

10 jQuery Accordionsタブ

10 jqueryプラグインをチェックする価値があります 10 jqueryプラグインをチェックする価値があります Mar 01, 2025 am 01:29 AM

10 jqueryプラグインをチェックする価値があります

ノードとHTTPコンソールを使用したHTTPデバッグ ノードとHTTPコンソールを使用したHTTPデバッグ Mar 01, 2025 am 01:37 AM

ノードとHTTPコンソールを使用したHTTPデバッグ

カスタムGoogle検索APIセットアップチュートリアル カスタムGoogle検索APIセットアップチュートリアル Mar 04, 2025 am 01:06 AM

カスタムGoogle検索APIセットアップチュートリアル

jQueryはscrollbarをdivに追加します jQueryはscrollbarをdivに追加します Mar 01, 2025 am 01:30 AM

jQueryはscrollbarをdivに追加します

See all articles