URLからGETパラメータを取得する
URLからGETパラメータを取得するときは、URLからURLSearchParamsオブジェクトを作成してメソッドを実行することで取得することができます。
URLSearchParamsオブジェクトはGETパラメータを取得するメソッドが6種類用意されています。
メソッド名 | 取得する値 |
---|---|
getメソッド | 指定したパラメータの名前を渡すと値を返します。同じ名前のパラメータが複数ある場合は最初の1つのみ値を返します。 |
getAllメソッド | 指定したパラメータの値を配列形式で返します。同じ名前のパラメータが複数ある場合も全ての値を取得することができます。 |
forEachメソッド | パラメータ名と値の組み合わせを取得して、指定した関数に渡します。 |
entriesメソッド | パラメータ名と値の組み合わせを配列形式(2次元配列)で返します。 |
keysメソッド | 全てのパラメータ名を配列で形式返します。値は含みません。 |
valuesメソッド | パラメータの値を配列で形式返します。パラメータ名は含みません。 |
以下の例は、対象URLに対してそれぞれのメソッドを実行し、取得した値をコンソールに出力します。
DEMOページより下記コードの実行例を確認できます(ブラウザのコンソールよりconsole.logの出力を確認してください)。
JavaScript コード例
// 対象URL:https://gray-code.com/js_sample/url1.html?id=5&username=taro&mode=read&aid=gc39195&mode=premium&mode=testuser
// URLを取得
let url = new URL(window.location.href);
// URLSearchParamsオブジェクトを取得
let params = url.searchParams;
// getメソッド
console.log(params.get('id')); // 5
console.log(params.get('mode')); // read
// getAllメソッド
console.log(params.getAll('mode'));
// (3) ["read", "premium", "testuser"]
// forEachメソッド
params.forEach(function(value,key){
console.log(key + " => " + value);
});
// id => 5
// username => taro
// mode => read
// aid => gc39195
// mode => premium
// mode => testuser
// entriesメソッド
let entries = params.entries();
for(let entry of entries) {
console.log(entry[0] + " => " + entry[1]);
}
// id => 5
// username => taro
// mode => read
// aid => gc39195
// mode => premium
// mode => testuser
// keysメソッド
let keys = params.keys();
for(let key of keys) {
console.log(key);
}
// id
// username
// mode
// aid
// mode
// mode
// valuesメソッド
let values = params.values();
for(let value of values) {
console.log(value);
}
// 5
// taro
// read
// gc39195
// premium
// testuser