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

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

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

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

2回答

2031閲覧

【JavaScript】input要素に半角数字のみ受け付けるif文を書いても反映されなくなった

itzuakniami123

総合スコア74

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2020/03/25 03:38

編集2020/03/25 04:03

前提・実現したいこと

ボタンを押して+1、-1の処理をしつつ手入力でも修正できるようなプログラムを作成しています。
入力したいものは半角数字のみなので、if文を用いて半角数字以外(ゼロ埋め含む)をはじく(=何もしない)処理を書いたのですが
上手く反映されず困っています。

なお、現在の得点と手入力修正欄のinput要素はあえてリンクさせています。

参考にしたURL 正規表現を用いて JavaScript で数値チェックを行う方法

実装前のプログラム

イメージ説明

HTML

1<!DOCTYPE html> 2<html lang="ja"> 3<head> 4 <meta charset="UTF-8" /> 5 <title>半角数字判定</title> 6 <meta content="width=device-width, initial-scale=1.0" name="viewport"> 7 <link rel="stylesheet" href="style.css" /> 8</head> 9<body> 10 <div id="score"> 11 <div class="flx"> 12 <h3>現在の得点</h3> 13 <p id="num">0</p> 14 </div><!-- /.flx --> 15 </div><!-- /#score --> 16 17 <div id="box"> 18 <h5>▼点数手入力修正 【半角数字のみ】</h5> 19 <div class="flx"> 20 <input type="text" value="0" id="input" /> 21 <input type="button" onclick="func1()" value="確定" id="decide"/> 22 </div><!-- /.flx --> 23 24 <div class="flx"> 25 <input type="button" id="one_up" onclick="down_up1(this.value)" value="+1"/> 26 <input type="button" id="one_down" onclick="down_up1(this.value)" value="-1"/> 27 </div><!-- /.flx --> 28 </div> 29 30 <script src="script.js"></script> 31</body> 32</html>

CSS

1*{ 2 padding:0; 3 margin: 0; 4} 5html{ 6 font-size:62.5%; 7 width: 1920px; 8 height: 1080px; 9} 10body{ 11 font-size:1.6rem; 12} 13.flx{ 14 display: flex; 15 flex-wrap: wrap; 16 margin-top: 17px; 17 margin-bottom:17px; 18} 19#score{ 20 width: 230px; 21 height: 50px; 22 margin-left:20px; 23} 24#score h3{ 25 margin:auto; 26} 27#num{ 28 display:block; 29 width: 75px; 30 height: 50px; 31 font-size:3rem; 32 padding-top: 5px; 33} 34#box{ 35 display:block; 36 width: 230px; 37 margin-left: 50px; 38 margin-top: 20px; 39 padding:10px; 40 background-color: #f90; 41} 42#one_up,#one_down{ 43 display: block; 44 margin:0 auto; 45 font-size:20px; 46 border-radius:10px; 47 padding:10px; 48 cursor:pointer; 49} 50#decide{ 51 margin-left: 10px; 52 padding: .4rem; 53 border-radius: .5rem; 54 cursor:pointer; 55}

JavaScript

1//ボタンを押したら±1する 2function down_up1(num) { 3 target = document.getElementById("input") 4 target2 = document.getElementById("num") 5 target_num = parseInt(target.value) 6 get_num = parseInt(num) 7 new_target_num = target_num + get_num 8 if (new_target_num < 0) { 9 new_target_num = 0 10 } 11 target2.innerHTML = target.value = new_target_num 12} 13//確定ボタンを押したときの動き 14function func1() { 15 let input_num = document.getElementById("input").value; 16 //int型に変換 17 let int_input_num = parseInt(input_num, 10); 18 document.getElementById("num").innerHTML = int_input_num; 19}

試したこと

その1 手入力された値をint型に変換し、その値が半角数字であるなら反映させる

JavaScript

1function func1() { 2 let input_num = document.getElementById("num").value; 3 let int_input_num = parseInt(input_num, 10); /* int型 */ 4 if (int_input_num == /^([1-9]\d*|0)$/) { 5 document.getElementById("num").innerHTML = int_input_num; 6 } 7}

その2 str型の時点でふるいにかける

JavaScript

1function func1() { 2 let input_num = document.getElementById("input").value; 3 if (input_num == /^([1-9]\d*|0)$/) { 4 //int型に変換 5 let int_input_num = parseInt(input_num, 10); 6 document.getElementById("num").innerHTML = int_input_num; 7 } 8}

上記のプログラムで起きた現象

例)半角数字4を押しても反映されないが、+1ボタンを押すと5になる
その1とその2で試してみましたが、同じ結果になっていましました。

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

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

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

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

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

guest

回答2

0

ベストアンサー

こういうことかな。。(修正版)

//確定ボタンを押したときの動き function func1() { let input_num = document.getElementById("input"); let num = document.getElementById("num"); if (numberCheck(input_num.value)) { let ok_num = Number(input_num.value); num.textContent = ok_num; input_num.value = ok_num; }else{ input_num.value = num.textContent; } } function numberCheck(numVal){ var pattern = /^([1-9]\d*|0)$/; return pattern.test(numVal); }

投稿2020/03/25 07:01

編集2020/03/26 01:51
Yousuck

総合スコア349

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

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

itzuakniami123

2020/03/25 08:40

Yousuck様 返事が遅くなり申し訳ありません。 ご回答ありがとうございます!やりたいことにとても近いのですが、ゼロ埋め(例:009、01)は確定したときに反映したくないので、その場合はどういった感じになりますでしょうか? ご提示していただいたプログラムをもとに実行してみたところ 初期値0に半角数字001を入力→確定ボタンを押す→001と表示されてしまう +1を押すと2と表記されてしまうので…。
Yousuck

2020/03/26 01:14

ゼロ埋め削除するようにしました。
itzuakniami123

2020/03/26 02:39

まさにこの通りの動きです! とても見やすく、自分が書いたプログラムと何が違うのか見比べながら今後も頑張りたいと思います。 ゼロ埋めのご対応ありがとうございます!
guest

0

指摘するにはちょっとな感じなので、こんなふうにしてみてください

投稿2020/03/25 04:01

編集2020/03/25 04:10
yambejp

総合スコア116724

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

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

yambejp

2020/03/25 04:10 編集

<script> window.addEventListener('DOMContentLoaded', ()=>{ document.querySelector('#input').addEventListener('input',e=>{ var v=e.target.value; var reg=/\D/; if(reg.test(v)) e.target.value=v.replace(reg,''); }); document.querySelectorAll('.change').forEach(x=>{ x.addEventListener('click',e=>{ var ele=document.querySelector('#input'); var v=parseInt(ele.value)||0; ele.value=v+parseInt(x.dataset["value"]); }); }); }); </script> <input type="text" value="0" id="input"> <input type="button" class="change" data-value="+1" value="+1"/> <input type="button" class="change" data-value="-1" value="-1"/>
itzuakniami123

2020/03/25 04:16

yambejp様 ご回答ありがとうございます。 当方としては、誤操作防止の為に必ず一度確定ボタンを押して手入力した値を反映させたい(innerHTML)のでご提示していただいた感じだと少し異なるかなと思います…。
yambejp

2020/03/25 07:06 編集

そうなると確定しないで+/-したときの仕様がわかりません 手入力前の数値に戻すのでしょうか? また確定で弾くなら半角数字以外の入力はできてしまっていいのですね?
itzuakniami123

2020/03/25 07:13

例えばですが、任意で半角数字4を入力する→反映される 半角数字以外を入力する→この処理は受け付けない(=表示は4のまま) +1すると5になる、-1すると3になるといった処理にしたいです…。 説明下手ですみません…。 初期値は0で、この場合も同じく 半角数字以外→受け付けない(=0のまま) +1すると1、-1をするとマイナス表示はしたくないのでどんなに-1ボタンを押しても表示は0になるようにしたいです。 マイナス表示にしない処理は既に function down_up1(num) { target = document.getElementById("input") target2 = document.getElementById("num") target_num = parseInt(target.value) get_num = parseInt(num) new_target_num = target_num + get_num if (new_target_num < 0) { new_target_num = 0 } target2.innerHTML = target.value = new_target_num } ここの部分で行っています。
yambejp

2020/03/25 07:16

> 半角数字4を入力する→反映される 確定はしないのですか? たとえば0だったのを4aと入力して確定すると0に戻るのかと 思ったのですが
itzuakniami123

2020/03/25 08:32 編集

返信が遅くなり申し訳ありません。 正しく言うと 半角数字4を入力する→確定ボタンを押す→反映される になります。 半角数字以外を入力→確定ボタンを押しても受け付けない という風にしたいので… >たとえば0だったのを4aと入力して確定すると0に戻る 強制的に0にするというよりかは、そもそも半角数字以外だったら確定ボタンを押しても何も処理しない(=pass)形になります。
yambejp

2020/03/25 08:34

> 確定ボタンを押しても受け付けない だんだんわかってきました。 確定ボタンが押せなければいいのですね? ちなみに不正なデータがあるときに+/-は押せるのでしょうか? その場合の挙動はどうなりますか?
yambejp

2020/03/25 08:43

押せなくするなら <script> window.addEventListener('DOMContentLoaded', ()=>{ document.querySelector('#decide').addEventListener('click',e=>{ document.querySelector('#num').textContent=document.querySelector('#input').value; }); document.querySelector('#input').addEventListener('input',e=>{ var v=e.target.value; var reg=/\D/; var flg=reg.test(v); document.querySelector('#decide').disabled=flg; document.querySelectorAll('.change').forEach(x=>{ x.disabled=flg; }); }); document.querySelectorAll('.change').forEach(x=>{ x.addEventListener('click',e=>{ var ele=document.querySelector('#input'); var v=parseInt(ele.value)||0; ele.value=v+parseInt(x.dataset["value"]); }); }); }); </script> <p id="num">0</p> <input type="text" value="0" id="input"> <input type="button" value="確定" id="decide"><br> <input type="button" class="change" data-value="+1" value="+1"/> <input type="button" class="change" data-value="-1" value="-1"/>
itzuakniami123

2020/03/25 09:18

ご丁寧にありがとうございます。 やりたいことはどちらかというとYousuck様が提示してくださったプログラムに近いです。 あとはこれにゼロ埋め(例:009、01)を受け付けないようにしたいです…。 >ちなみに不正なデータがあるときに+/-は押せるのでしょうか? 不正なデータというのは半角数字以外のことでしょうか? 当方の定義する不正なデータは 全角・半角文字(漢字・カタカナ・ひらがな)、記号(少数点含む)なので 不正なデータが紛れ込むケースは手入力する際に起こりうると考えています。 なので、確定ボタンを押した際にチェックする処理をいれたくてif文で作成しています。
yambejp

2020/03/25 09:40

落とし所がわからない・・・ <script> window.addEventListener('DOMContentLoaded', ()=>{ const validate=()=>{ var v=document.querySelector('#input').value; var reg=/^([1-9]\d*|0)$/; return reg.test(v); }; document.querySelector('#decide').addEventListener('click',e=>{ if(validate()) document.querySelector('#num').textContent=document.querySelector('#input').value; }); document.querySelectorAll('.change').forEach(x=>{ x.addEventListener('click',e=>{ if(validate()){ var ele=document.querySelector('#input'); var v=parseInt(ele.value)+parseInt(x.dataset["value"]); if(v<0) v=0; ele.value=v; } }); }); }); </script> <p id="num">0</p> <input type="text" value="0" id="input"> <input type="button" value="確定" id="decide"><br> <input type="button" class="change" data-value="+1" value="+1"/> <input type="button" class="change" data-value="-1" value="-1"/>
itzuakniami123

2020/03/26 02:40

説明下手で本当にすみません…。 実現したい動きはベストアンサーに選出したプログラムになります。 お付き合いいただきありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問