パラメータを取得する(URLSearchParams):params.get
以下のようなコードで、現在のページのURLからパラメータを取得し、条件に応じてリダイレクトするかどうかを切り分けることができます。
// 現在のURLからパラメータを取得する
const params = new URLSearchParams(window.location.search);
// パラメータ名が "redirect" で、値が "true" の場合にリダイレクトする
if (params.get("redirect") === "true") {
window.location.href = "http://example.com/redirected-page";
} else {
// リダイレクトしない場合の処理をここに書く
}
このコードでは、window.location.search
で現在のURLのクエリストリングを取得しています。それを URLSearchParams
オブジェクトに変換し、get
メソッドを使ってパラメータの値を取得しています。
そして、取得した値が “true” であれば、window.location.href
を使ってリダイレクト先のURLに遷移します。そうでなければ、リダイレクトしない場合の処理を行います。
https://contact.eguweb.tech/569/?redirect=false
https://contact.eguweb.tech/569/?redirect=true
リダイレクトされるかどうか?を、パラメータで条件を分ることで、挙動を変えることができました。
?redirect=trueの場合のみ、リダイレクトされます。
[rml_read_more]
パラメータそのものが設定されているかどうか?を分けるには:params.has
以下のようなコードで、現在のページにパラメータが設定されているかどうかを判定し、条件分岐することができます。
// 現在のURLからパラメータを取得する
const params = new URLSearchParams(window.location.search);
// パラメータが設定されている場合に処理を行う
if (params.has("paramName")) {
// パラメータが設定されている場合の処理をここに書く
} else {
// パラメータが設定されていない場合の処理をここに書く
}
このコードでは、has メソッドを使って、指定したパラメータが存在するかどうかを判定しています。もし指定したパラメータが存在すれば、if 文の中の処理が実行されます。パラメータが存在しない場合は、else 文の中の処理が実行されます。
ここで paramName は、実際のパラメータ名に置き換えてください。また、パラメータ名が複数ある場合には、複数回の has メソッドの呼び出しや、Array.includes メソッドを使って判定することもできます。