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

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

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

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

jQuery

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

Q&A

解決済

3回答

2920閲覧

[jquery] URLから1つのキーが持つ複数の値を全て取得したい

kotahayashi

総合スコア15

JavaScript

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

jQuery

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

0グッド

0クリップ

投稿2018/04/14 06:08

前提・実現したいこと

javascriptで、URLからパラメータの値を取得しようと試みています。
1つのキーに対し1つの値が対応している場合は以下のコードで取得できているのですが、
1つのキーが複数の値を持つ場合、最後に表示される値しか取得できません。
この複数の値を全て取得したいと考えています。

発生している問題・エラーメッセージ

当該ページのURL
http://localhost:3000/index?key%5B%5D=2&key%5B%5D=3

以下、 console.log(arg.key)の結果

3

該当のソースコード

javascript

1 var arg = new Object; 2 var url = location.search.substring(1).split('&'); 3 for (var i = 0; url[i]; i++) { 4 var k = url[i].split('%5B%5D='); 5 arg[k[0]] = k[1]; 6 } 7 console.log(arg.key); 8 9

上記の例では、[2, 3]という配列を出力できればと考えています。

よろしくお願いいたします。

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

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

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

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

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

guest

回答3

0

投稿2018/04/14 06:33

編集2018/04/14 06:35
think49

総合スコア18162

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

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

think49

2018/04/14 06:37

MDNのサンプルが悪いですね。 URLSearchParamsコンストラクタを使わずとも、プロパティから参照可能です。
defghi1977

2018/04/14 06:39

getAllのほうが適切ですね
guest

0

ベストアンサー

URLSearchParamsを使った方法です。

JavaScript

1//let paramsString = "?key%5B%5D=2&key%5B%5D=3"; 2let paramsString = location.search; 3let searchParams = new URLSearchParams(paramsString); 4console.log(searchParams.getAll("key[]"));

◇余談
parameterのkey%5B%5Dですが、もしも変更できるならKey=カンマ区切りにして値を渡すほうがシンプルになるかと。

JavaScript

1Key=1,2

投稿2018/04/14 06:39

umyu

総合スコア5846

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

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

think49

2018/04/14 07:07

> Key=1,2 JavaScriptではCSVパーサが標準化されていないので、エスケープが必要な値だとparse処理が余計にかかります。 また、PHPの場合は key[] で渡せば自動的に配列化されるので、現状も悪くはないと思っています。
umyu

2018/04/14 07:12

>think49さんへ なるほど、参考になります。
kotahayashi

2018/04/14 09:00

皆様ご回答くださりありがとうございました。 初心者の私にも大変わかりやすいご回答で、このまま実装しましたので、こちらをベストアンサーといたしました。 ちなみにですが、ruby on railsを使用しています。一部のキーはkey[]のように配列で渡しています。
guest

0

この手のURLの解析は手で行なってはなりません. 専用のAPIが用意されているので, それを使いましょう.

JavaScript

1const url = new URL("http://localhost:3000/index?key%5B%5D=2&key%5B%5D=3"); 2const values = [...url.searchParams.values()]; 3//[ "2", "3" ] 4 5//getAllで釣るほうが良かろう 6console.log(url.searchParams.getAll(decodeURI("key%5B%5D"))); 7//[ "2", "3" ]

https://developer.mozilla.org/ja/docs/Web/API/URL/URL
https://developer.mozilla.org/ja/docs/Web/API/URL/searchParams
https://developer.mozilla.org/ja/docs/Web/API/URLSearchParams/values
https://developer.mozilla.org/ja/docs/Web/JavaScript/Reference/Iteration_protocols
https://developer.mozilla.org/ja/docs/Web/API/URLSearchParams/getAll

投稿2018/04/14 06:37

編集2018/04/14 06:42
defghi1977

総合スコア4756

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問