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

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

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

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

jQuery

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

Q&A

解決済

3回答

2972閲覧

全角数字を半角数字にリアルタイムに置き換える処理で全角の「0」だけ半角「00」に置き換えられてしまう

0x00000124

総合スコア7

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

jQuery

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

1グッド

0クリップ

投稿2022/06/21 21:22

jQueryを利用して、入力された電話番号をリアルタイムに半角に直す制御を記述しております。

WindowsのChrome、Edge、MacのSafariで検証したところ、全角モードで「0」を入力した場合だけ、半角の「0」の1文字に変換されるべきところが、半角の「00」になってしまう時がある問題にぶつかっております。他の全角「1〜9」についてはこの事象は発生しておりません。

全角「0」だけこの事象が発生する原因がわからず、解決に向けてお力添えをいただきたいです。

なお、MacのChromeでは発生しないようです。

発生しているバージョン

  • OS: Windows 10 21H1 19043.1766
  • ブラウザ: Chrome 103.0.5060.33
  • jQuery: 3.4.1(codepen上でjquery 3.6.0を指定し下記コードをセットしても同様でした)

html

1<input minlength="9" id="tel" type="tel" name="tel">

javascript

1$("#tel").on("keydown keyup input change blur", function (e) { 2 var value = $(e.currentTarget).val(); 3 value = value 4 .replace(/[0-9]/g, function(s) { 5 return String.fromCharCode(s.charCodeAt(0) - 65248); 6 }) 7 .replace(/[^0-9]/g, ''); 8 $(e.currentTarget).val(value); 9});
Maximillion👍を押しています

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

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

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

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

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

maisumakun

2022/06/21 22:36

> 全角モードで「0」を入力した場合だけ テンキーとフルキーのどちらかでだけ発生する、というような傾向はありますか?
0x00000124

2022/06/22 07:17

テンキーでは発生しないですね。フルキーのみで発生しております。 よろしくお願いします
guest

回答3

0

ベストアンサー

https://teratail.com/questions/qgveiam8wwb9dc
こちらの質問と回答が参考になるかもしれません。

投稿2022/06/21 23:16

int32_t

総合スコア20872

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

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

0x00000124

2022/06/23 05:12

compositionstart, compositionendで実装したところ00になるバグを解消できましたのでこちらをベストアンサーにさせていただければと思います。ありがとうございました
guest

0

入力された電話番号をリアルタイムに半角に直す制御を記述しております。

本題ではありませんが、入力中に値を変更すると「変換しようと思っていたものが強制的に確定させられる」など、入力側から意図しない動作となりがちです。

内輪でしか使わない、あるいは入念に動作を練った上で行うなら話は別ですが、変換はフォーカスの外れたときに一括して行う、ほうが操作性として上回る可能性もあります。

投稿2022/06/21 22:39

maisumakun

総合スコア145183

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

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

0

見た感じ問題なさそうですけどね
jQueryなのにthisを使わないところとか違和感ありますが

javascript

1<script> 2window.addEventListener('DOMContentLoaded', ()=>{ 3 tel.addEventListener('input',()=>{ 4 const v=tel.value; 5 if(/\D/.test(v)){ 6 tel.value=v.replace(/[0-9]/g,x=>String.fromCharCode(x.charCodeAt(0) - 65248)).replace(/\D/g,''); 7 } 8 }); 9}); 10</script> 11<input minlength="9" id="tel" type="tel" name="tel"> 12

バリデートだけならinputにpattern設定するだけでもよいかも

投稿2022/06/22 01:36

yambejp

総合スコア114829

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問