質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Q&A

解決済

3回答

206閲覧

数値項目を入力してもらうINPUT TYPE=TEXTの要素、前0入力を抑制したい

saya24

総合スコア222

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

0グッド

0クリップ

投稿2019/01/31 06:58

現況は当該要素に数値項目のみ入力可能なよう以下コーディング(JQuery)となっています。

こちらについても支援を仰ぎまして達成したもので、標題の件を達成する上での
応用能力がなくお問合せさせて頂きました。

そもそも数値項目の入力制御、皆さんどうされているのですか。質問主旨から離れてしまいますが。
皆さんが必要と思う機能だと思うのですが...
毛嫌いしているフレームワークで作れば(CAKEPHP理解できず断念) こういったUIの問題も解消されるのかな

HTML

1<tr> 2 <td style="width: 9%;"><input type="hidden" name="rsvno"><button class="cdsrch" type="button"><img src="img/検索.png"></button><input type="text" name="cd[]" style="width: 64%; ime-mode: inactive;" /></td> 3 <td style="width: 31%;"><input type="text" name="name[]" style="width: 100%;" readonly /></td> 4 <td style="width: 15%;"><input type="text" name="capa[]" style="width: 100%;" readonly /></td> 5 <td style="width: 12%;"><button class="lotsrch" type="button"><img src="img/検索.png"></button><input type="text" name="lot[]" style="width: 75%; ime-mode: inactive;" /></td> 6 <td style="width: 7%;"><input type="text" name="reqrsv[]" style="width: 92%; ime-mode: inactive;" /></td> 7 <td style="width: 8%;"><input type="text" name="custockl[]" style="width: 95%;" readonly /></td> 8 <td style="width: 10%;"><input type="text" name="custocka[]" style="width: 95%;" readonly /></td> 9 <td style="width: 2%;"><span class="errmark" style="width: 100%;"></span></td> 10 <td style="width: 3%;"><button class="rowins" type="button" style="width: 100%;">+</button></td> 11 <td style="width: 3%;"><button class="rowdel" type="button" style="width: 100%;">-</button></td> 12</tr>

JQuery

1$("[name='reqrsv[]']").on({ 2 "keydown": function(e) { 3 var k = e.keyCode; 4 if (!(k >= 48 && k <= 57 || k >= 96 && k <= 105 || k == 32 || k == 8 || k == 9 || k == 46 || k == 39 || k == 37)) { 5 return false; 6 } 7 }, 8 "blur": function() { 9 var num = $(this).val(); 10 num = num.replace(/(\d)(?=(\d\d\d)+$)/g, "$1,"); 11 $(this).val(num); 12 }, 13 "focus": function(e) { 14 var num = $(this).val(); 15 num = num.replace(/,/g, ""); 16 $(this).val(num); 17 if (this.selectionStart != null) { 18 this.selectionStart = this.selectionEnd = this.value.length; 19 } else { 20 this.createTextRange().select(); 21 } 22 } 23 });

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

そもそも数値項目の入力制御、皆さんどうされているのですか

<input type="number">でだいたい済ませていますが、何かこれでは不足なのでしょうか。

投稿2019/01/31 07:00

maisumakun

総合スコア145183

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

saya24

2019/01/31 09:04

ご見解ありがとうございます、早速試しました。 当方の掲載したコーディングですが、どこかの掲示板でカンマ付けを都合よく対応するには?という問合せをしてこうなった可能性がありますね。 type=numberは、入力して当該要素からフォーカスが外れたとき、カンマ表示をしてくれないのですよね?? 自分が採用しているコーディングをよく解読できませんが、フォーカスしたときはカンマを逆に取り除くことをやっている気がします。(空に修整した場合「,」が残るからかな??)
maisumakun

2019/01/31 09:06

はい、カンマが入るときにはtype=numberは向かないですね。
saya24

2019/01/31 09:15

了解しました。 採用しているコーディングの意味合い、背景をあとから思い出して皆様の貴重なお時間を頂いてしまいました。 となると、【前0除去】は、このコーディング内で対応せざるを得ない、ということですかね??数値のみの入力を達成しつつ、カンマ表示を達成したい場合は
saya24

2019/02/01 01:20 編集

ベストな方針か分かりませんが自己解決しました。 数値項目入力枠を、カンマ表示を達成しつつ前0入力は抑制する手段、(相応のライブラリ利用しない場合) 解決方法のところに入力しました...
guest

0

導入部分としてtype=numberは有用ですし、pattern属性もありだと思います。

ただいずれにしてもクライアントサイドである以上は改ざんが可能なので、
サーバーサイドでのチェックを行います。

投稿2019/01/31 07:05

m.ts10806

総合スコア80850

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

自己解決

JQuery

1$("[name='reqrsv[]']").on("change",function() { 2 var valbyte = $(this).val().length; 3 var newval = $(this).val(); 4 for (var i = 1; i <= valbyte; i++) { 5 if (newval.substr(0,1) == 0) { 6 newval = newval.substr(1); 7 } else { 8 break; 9 } 10 } 11 $(this).val(newval); 12});

投稿2019/02/01 01:20

saya24

総合スコア222

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問