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

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

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

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

jQuery

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

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

解決済

1回答

435閲覧

HTMLのフォームで時間を入力する際:を抜いて入力でき、外れると:をつけたい

pepe1122

総合スコア14

JavaScript

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

jQuery

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

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

0クリップ

投稿2020/09/29 18:37

時間を入力する際jsで値を変えたい

htmlのinputのフォームで
入力時は【1200】 選択が外れると【12:00】にしたいです。
【200】なども【02:00】にしたいです。

その他時間ではない数字や文字がはいったときは空白にするつもりです。

またできれば、
全角数字全角【:】にも対応したいです

該当のソースコード

html

1<section class="content"> 2 <form method="post"> 3 <div> 4 <label for="time">時間</label> 5 <input type="text" id="time" name="time" value="time" placeholder=""> 6 </div> 7</section>

js

1 2 let $time = $('#time'); 3 4 $time.focusin(function () { 5 let value = $(this).val().replace(":", ""); 6 $(this).val(value); 7 }); 8 9 10 $time.focusout(function () { 11 if(!isNaN(time)){ 12 $(this).val(""); 13 } 14 time.value = strIns(time.value, 2, ':'); 15 }); 16 17 function strIns(str, idx, val){ 18 return str.slice(0, idx) + val + str.slice(idx); 19 }

フォーカスインで外れるのは確認できたのですが
アウトでうまく:がついてくれません。
ご教授よろしくお願いします。

補足情報

pythonとhtmlとjq使用しています。

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

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

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

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

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

m.ts10806

2020/09/29 23:20 編集

ちなみに確認したブラウザは何でしょうか。 こちらの手元では「アウトでうまく:がついてくれません。」は起きず、ちゃんとついてくれます。Wiindows10,Chrome85.0(現時点の最新) jQuery v3.5.1 CDN 気になるのは、しいてなら 200→20:0 になるということくらいでしょうか。 12時間形式か24時間形式か決めないといけないかと思います。
pepe1122

2020/09/30 00:07

ありがとうございます。そうなのですね! 確認したブラウザはchromeでjQuery v3.3.1です。 24時で想定しております。
m.ts10806

2020/09/30 00:10 編集

3.3.1でも動きました。バージョンはあまり関係ないとは思います。 ただ、 12:00→12::00 12::00→12:00 となるので、抜けは結構ありそうです。
guest

回答1

0

ベストアンサー

どこまでチェックしたいかによりますね
ユーザーには数値しか入れられないようにするほうがよいかと

投稿2020/09/30 07:52

yambejp

総合スコア114915

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

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

yambejp

2020/09/30 07:52

<script> window.addEventListener('DOMContentLoaded', ()=>{ const t=document.querySelector('#time'); t.addEventListener('focus',function(){ t.value=t.value.replace(/:/,''); }); t.addEventListener('input',function(){ if(/[^\d]/.test(t.value)) t.value=t.value.replace(/[^d]/,''); }); var m; t.addEventListener('blur',function(){ if(m=t.value.match(/^\d$/)){ t.value=`0${m[0]}:00`; }else if(m=t.value.match(/^([01]\d|2[0-3])$/)){ t.value=`${m[0]}:00`; }else if(m=t.value.match(/^(\d)([0-5]\d)$/)){ t.value=`0${m[1]}:${m[2]}`; }else if(m=t.value.match(/^([01]\d|2[0-3])([0-5]\d)$/)){ t.value=`${m[1]}:${m[2]}`; }else{ t.value=""; } }); }); </script> <form> <input type="text" id="time" name="time" pattern="([01]\d|2[0-3]):?[0-5]\d" placeholder=""> <input type="submit" value="send"> </form>
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問