URLSearchParams

URLSearchParams インターフェイスは URL のクエリー文字列の操作に役立つメソッドを定義します。

URLSearchParams を実装しているオブジェクトは、for...of 構造の中で直接使用して、キーと値のペアをクエリー文字列に現れるのと同じ順序で反復処理することができます。例えば次の 2 行は等価です。

js
for (const [key, value] of mySearchParams) {
}
for (const [key, value] of mySearchParams.entries()) {
}

メモ: この機能はウェブワーカー内で利用可能です。

コンストラクター

URLSearchParams()

URLSearchParams オブジェクトを返すコンストラクターです。

インスタンスプロパティ

size

検索パラメーター項目の総数を示します。

インスタンスメソッド

URLSearchParams.[@@iterator]()

このオブジェクトに含まれるすべてのキーと値のペアを、クエリー文字列に現れるのと同じ順序で反復処理することができるイテレーターを返します。

URLSearchParams.append()

指定されたキーと値のペアを新しい検索パラメーターとして追加します。

URLSearchParams.delete()

指定された名前と値に一致する検索パラメーターを、検索パラメーターのリストからすべて削除します。

URLSearchParams.entries()

このオブジェクトに含まれるすべてのキーと値のペアを、クエリー文字列に現れるのと同じ順序で反復処理することができるイテレーターを返します。

URLSearchParams.forEach()

コールバック関数を介して、このオブジェクトに含まれるすべての値を反復処理します。

URLSearchParams.get()

指定された検索パラメーターに対応する最初の値を返します。

URLSearchParams.getAll()

指定された検索パラメーターに対応するすべての値を返します。

URLSearchParams.has()

指定されたパラメーター、またはパラメーターと値のペアが存在するかどうかを示す論理値を返します。

URLSearchParams.keys()

このオブジェクトに含まれるすべてのキーと値のペアのキーを反復処理する イテレーターを返します。

URLSearchParams.set()

指定された検索パラメーターに結び付けられた値を指定された値に設定します。複数の値が存在していた場合、他のものは削除されます。

URLSearchParams.sort()

すべてのキーと値のペアを、キーを基準にソートします。

URLSearchParams.toString()

URL で使用するのに適したクエリー文字列を返します。

URLSearchParams.values()

このオブジェクトに含まれるすべてのキーと値のペアの値を反復処理する イテレーターを返します。

js
const paramsString = "q=URLUtils.searchParams&topic=api";
const searchParams = new URLSearchParams(paramsString);

// 検索パラメーターの列挙
for (const p of searchParams) {
  console.log(p);
}

console.log(searchParams.has("topic")); // true
console.log(searchParams.has("topic", "fish")); // false
console.log(searchParams.get("topic") === "api"); // true
console.log(searchParams.getAll("topic")); // ["api"]
console.log(searchParams.get("foo") === null); // true
console.log(searchParams.append("topic", "webdev"));
console.log(searchParams.toString()); // "q=URLUtils.searchParams&topic=api&topic=webdev"
console.log(searchParams.set("topic", "More webdev"));
console.log(searchParams.toString()); // "q=URLUtils.searchParams&topic=More+webdev"
console.log(searchParams.delete("topic"));
console.log(searchParams.toString()); // "q=URLUtils.searchParams"
js
// 検索パラメーターはオブジェクトにすることもできる
const paramsObj = { foo: "bar", baz: "bar" };
const searchParams = new URLSearchParams(paramsObj);

console.log(searchParams.toString()); // "foo=bar&baz=bar"
console.log(searchParams.has("foo")); // true
console.log(searchParams.get("foo")); // "bar"

重複する検索パラメーター

js
const paramStr = "foo=bar&foo=baz";
const searchParams = new URLSearchParams(paramStr);

console.log(searchParams.toString()); // "foo=bar&foo=baz"
console.log(searchParams.has("foo")); // true
console.log(searchParams.get("foo")); // bar (最初の値のみを返す)
console.log(searchParams.getAll("foo")); // ["bar", "baz"]

URL の解釈なし

URLSearchParams コンストラクターは URL 全体を解釈しません。しかし、文字列から最初の ? 以降が存在すれば、削除します。

js
const paramsString1 = "http://example.com/search?query=%40";
const searchParams1 = new URLSearchParams(paramsString1);

console.log(searchParams1.has("query")); // false
console.log(searchParams1.has("http://example.com/search?query")); // true

console.log(searchParams1.get("query")); // null
console.log(searchParams1.get("http://example.com/search?query")); // "@" (decodeURIComponent('%40') と同じ)

const paramsString2 = "?query=value";
const searchParams2 = new URLSearchParams(paramsString2);
console.log(searchParams2.has("query")); // true

const url = new URL("http://example.com/search?query=%40");
const searchParams3 = new URLSearchParams(url.search);
console.log(searchParams3.has("query")); // true

プラス記号の温存

URLSearchParams コンストラクターはプラス記号 (+) をスペースとして解釈します。以下の例では、16 進エスケープシーケンス を使って、URL 検索パラメーターに格納する必要のあるバイナリデータ(各バイトが情報を持つ)を含む文字列を模倣しています。btoa() でエンコードされた文字列は + を含んでおり、 URLSearchParams では温存されないことに注意してください。

js
const rawData = "\x13à\x17@\x1F\x80";
const base64Data = btoa(rawData); // 'E+AXQB+A'

const searchParams = new URLSearchParams(`bin=${base64Data}`); // 'bin=E+AXQB+A'
const binQuery = searchParams.get("bin"); // 'E AXQB A', '+' はスペースに置き換えられる

console.log(atob(binQuery) === rawData); // false

データを encodeURIComponent() でエンコードすることで、これを回避できます。

js
const rawData = "\x13à\x17@\x1F\x80";
const base64Data = btoa(rawData); // 'E+AXQB+A'
const encodedBase64Data = encodeURIComponent(base64Data); // 'E%2BAXQB%2BA'

const searchParams = new URLSearchParams(`bin=${encodedBase64Data}`); // 'bin=E%2BAXQB%2BA'
const binQuery = searchParams.get("bin"); // 'E+AXQB+A'

console.log(atob(binQuery) === rawData); // true

空の値と値なし

URLSearchParams= の後に何もないパラメーターと、= もないパラメーターの区別をしません。

js
const emptyVal = new URLSearchParams("foo=&bar=baz");
console.log(emptyVal.get("foo")); // '' を返す
const noEquals = new URLSearchParams("foo&bar=baz");
console.log(noEquals.get("foo")); // これも '' を返す
console.log(noEquals.toString()); // 'foo=&bar=baz'

仕様書

Specification
URL Standard
# urlsearchparams

ブラウザーの互換性

BCD tables only load in the browser

関連情報