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

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

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

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

Q&A

解決済

2回答

333閲覧

入力文字の制限について

pg_ri

総合スコア13

JavaScript

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

0グッド

0クリップ

投稿2018/08/22 07:09

入力文字の制限を行いたいと考えております。
教えていただきたいことは以下の2点です。

①半角カタカナ+改行のみ入力可
半角カタカナ+改行のみ入力可、としたいのですが、
改行するとエラーメッセージを出力してしまいます。
また、なぜか"11111a"はエラーになるのに対し、
"a11111"のように1文字目に半角英字が入った場合は、
エラーメッセージを出力せず、英字が入力できてしまいます。
現状の実装は上記の通りです。

JavaScript

1if (!取得した文字列.match(/[ヲ-゚ -]+$/)) { 2 エラーメッセージの出力 3}

【半角カタカナ+改行のみ入力可】+【先頭文字のチェックも含む】
とする方法を教えていただきたいです。

ちなみに、改行コード=¥n(半角)ということだったので、
.match(/[ヲ-゚ -¥n]+$/)も試してみましたが
改行できませんでした。

ーーー

②半角数字と一部記号(-,+)のみ入力可
半角数字と一部記号(-,+)のみ入力可、としたいのですが、
①と同様に、"a11111"のように1文字目に半角英字が入った場合は、
エラーメッセージを出力せず、英字が入力できてしまいます。
現状の実装は上記の通りです。

JavaScript

1if (!取得した文字列.match(/[0-9+-]+$/)) { 2 エラーメッセージの出力 3}

【半角数字と一部記号(-,+)のみ入力可】+【先頭文字のチェックも含む】
とする方法を教えていただきたいです。

ーーー

以上となります。宜しくお願い致します。

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

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

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

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

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

m.ts10806

2018/08/22 07:51

textareaに対する入力チェック(バリデーション)ということでよろしいですか?HTMLやサンプルで使っている入力文字列などもご提示いただければと思います。(再現確認と調整のため)
pg_ri

2018/08/22 08:28

ご指摘ありがとうございます。他の方の回答で私の質問内容については解決することができました。回答してくださる方が答えやすいようなもう少し具体的に端的な質問をするように心掛けたいと思います。
m.ts10806

2018/08/22 12:34

質問は編集できるので適宜対応していただけると回答もしやすくなります。
guest

回答2

0

ベストアンサー

match(/[ヲ-゚ -]+$/)

↑特殊文字「-」がエスケープされてない。
また、この書き方だと「(どの位置から開始していたとしても)末尾が半角カナならOK」という書き方になるので、

match(/^[ヲ-゚ \-\n]+$/)

match(/[0-9+-]+$/)

↑上記同様、「(どの位置から開始していたとしても)末尾が数字ならOK」「特殊文字がエスケープされてない」

match(/^[0-9+\-]+$/)

投稿2018/08/22 07:54

tkturbo

総合スコア5572

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

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

pg_ri

2018/08/22 08:25

とてもわかりやすくご教授いただきありがとうございました。 いただいたコードで試したところ、想定通りの動きになりました。
guest

0

①半角カタカナ+改行のみ入力可

javascript

1文字列.match(/^[ヲ-゚\n]+$/)

②半角数字と一部記号(-,+)のみ入力可

javascript

1文字列.match(/^[0-9+\-]+$/)

正規表現(/~/) の先頭にある^によって、
行頭からにされるので、先頭の文字までちゃんと検索されます。

(元のソースでは、行頭からにならないので、最初の文字は無視されてしまっています。)
($は逆に行末までという意味です。)

つまり、
文字列のすべてを検索したければ

  • 正規表現の先頭に ^
  • 正規表現の末尾に $

をつけましょう。

投稿2018/08/22 07:50

_lemon2003_

総合スコア274

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

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

_lemon2003_

2018/08/22 07:57

@tkturbo さんのおっしゃったとおり、ただの文字として扱うならエスケープ、文字列のすべてを評価したいときは`^`と`$`をつけるということですね。
pg_ri

2018/08/22 08:26

とてもわかりやすくご教授いただきありがとうございました。 いただいたコードで試したところ、想定通りの動きになりました。 行頭から行末まで、という方法が分かり大変助かりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問