別のWebページにリダイレクトするにはどうすればよいですか?

2009年02月02日に質問されました。  ·  閲覧回数 6.5M回  ·  ソース

venkatachalam picture
2009年02月02日

jQueryまたは純粋なJavaScriptを使用して、ユーザーをあるページから別のページにリダイレクトするにはどうすればよいですか?

回答

Ryan McGeary picture
2009年02月03日
15172

jQueryを使用してリダイレクトするだけではありません

jQueryは必要ありません。 window.location.replace(...)はHTTPリダイレクトを最もよくシミュレートします。

window.location.replace(...)は、 window.location.hrefを使用するよりも優れています。これは、 replace()がセッション履歴に元のページを保持しないため、ユーザーが終わりのないバックにとらわれることがないためです。ボタンの大失敗。

リンクをクリックする人をシミュレートする場合は、 location.href使用します

HTTPリダイレクトをシミュレートする場合は、 location.replace使用します

例えば:

// similar behavior as an HTTP redirect
window.location.replace("http://stackoverflow.com");

// similar behavior as clicking on a link
window.location.href = "http://stackoverflow.com";
Boris Guéry picture
2009年10月29日
1719

警告:この回答は、考えられる解決策として提供されたものにすぎません。 jQueryが必要なため、明らかに最善の解決策ではありません。 代わりに、純粋なJavaScriptソリューションをお勧めします。

$(location).attr('href', 'http://stackoverflow.com')
Mark Pieszak - Trilon.io picture
2012年07月27日
719

ページをリダイレクトする標準の「バニラ」JavaScriptの方法

window.location.href = 'newPage.html';

またはもっと簡単に:( windowはグローバルであるため)

location.href = 'newPage.html';

リダイレクト時にHTTP_REFERERが失われているためにここにいる場合は、以下を読み続けてください。

(それ以外の場合は、この最後の部分を無視してください)


次のセクションは、多くのセキュリティ対策の1つとしてHTTP_REFERERている人を対象としています(ただし、これは優れた保護対策ではありません)。 Internet Explorer 8以下を使用して

以下では、HTTP_REFERERが失われないように、 IE8以下の代替を実装します。 それ以外の場合は、ほとんどの場合、 window.location.href使用できます。

テストHTTP_REFERER (URLを貼り付け、セッションなど)は要求が正当であるかどうかを伝えることができます注:コメントのdroopのリンクに示されているように、これらのリファラーを回避/スプーフィングする方法もあります)


シンプルなクロスブラウザーテストソリューション(Internet Explorer 9以降および他のすべてのブラウザーのwindow.location.hrefへのフォールバック)

使用法: redirect('anotherpage.aspx');

function redirect (url) {
    var ua        = navigator.userAgent.toLowerCase(),
        isIE      = ua.indexOf('msie') !== -1,
        version   = parseInt(ua.substr(4, 2), 10);

    // Internet Explorer 8 and lower
    if (isIE && version < 9) {
        var link = document.createElement('a');
        link.href = url;
        document.body.appendChild(link);
        link.click();
    }

    // All other browsers can use the standard window.location.href (they don't lose HTTP_REFERER like Internet Explorer 8 & lower does)
    else { 
        window.location.href = url; 
    }
}
Govind Singh picture
2014年01月28日
440

これを行う方法はたくさんあります。

// window.location
window.location.replace('http://www.example.com')
window.location.assign('http://www.example.com')
window.location.href = 'http://www.example.com'
document.location.href = '/path'

// window.history
window.history.back()
window.history.go(-1)

// window.navigate; ONLY for old versions of Internet Explorer
window.navigate('top.jsp')


// Probably no bueno
self.location = 'http://www.example.com';
top.location = 'http://www.example.com';

// jQuery
$(location).attr('href','http://www.example.com')
$(window).attr('location','http://www.example.com')
$(location).prop('href', 'http://www.example.com')
Fred picture
2010年10月23日
340

これはすべてのブラウザで機能します。

window.location.href = 'your_url';
tvanfosson picture
2009年02月02日
303

あなたがやろうとしていることについてもう少し説明的であるならば、それは助けになるでしょう。 ページングされたデータを生成しようとしている場合、これを行う方法にはいくつかのオプションがあります。 直接アクセスできるようにするページごとに個別のリンクを生成できます。

<a href='/path-to-page?page=1' class='pager-link'>1</a>
<a href='/path-to-page?page=2' class='pager-link'>2</a>
<span class='pager-link current-page'>3</a>
...

例の現在のページは、コードとCSSで異なる方法で処理されることに注意してください。

ページングされたデータをAJAX経由で変更したい場合は、ここでjQueryが役立ちます。異なるページに対応する各アンカータグにクリックハンドラーを追加します。 このクリックハンドラーは、AJAXを介して次のページに移動してフェッチし、新しいデータでテーブルを更新するjQueryコードを呼び出します。 以下の例は、新しいページデータを返すWebサービスがあることを前提としています。

$(document).ready( function() {
    $('a.pager-link').click( function() {
        var page = $(this).attr('href').split(/\?/)[1];
        $.ajax({
            type: 'POST',
            url: '/path-to-service',
            data: page,
            success: function(content) {
               $('#myTable').html(content);  // replace
            }
        });
        return false; // to stop link
    });
});
Patartics Mil&#225;n picture
2013年04月25日
257

また、 location.replace(URL)が最善の方法だと思いますが、リダイレクトについて検索エンジンに通知する場合(JavaScriptコードを分析してリダイレクトを確認することはありません)、 rel="canonical"を追加する必要があります。あなたのウェブサイトへのメタタグ。

HTML更新メタタグを含むnoscriptセクションを追加することも良い解決策です。 このJavaScriptリダイレクトツールを使用してリダイレクトを作成することをお勧めします。 また、HTTPリファラーを渡すためのInternetExplorerもサポートしています。

遅延のないサンプルコードは次のようになります。

<!-- Place this snippet right after opening the head tag to make it work properly -->

<!-- This code is licensed under GNU GPL v3 -->
<!-- You are allowed to freely copy, distribute and use this code, but removing author credit is strictly prohibited -->
<!-- Generated by http://insider.zone/tools/client-side-url-redirect-generator/ -->

<!-- REDIRECTING STARTS -->
<link rel="canonical" href="https://yourdomain.com/"/>
<noscript>
    <meta http-equiv="refresh" content="0;URL=https://yourdomain.com/">
</noscript>
<!--[if lt IE 9]><script type="text/javascript">var IE_fix=true;</script><![endif]-->
<script type="text/javascript">
    var url = "https://yourdomain.com/";
    if(typeof IE_fix != "undefined") // IE8 and lower fix to pass the http referer
    {
        document.write("redirecting..."); // Don't remove this line or appendChild() will fail because it is called before document.onload to make the redirect as fast as possible. Nobody will see this text, it is only a tech fix.
        var referLink = document.createElement("a");
        referLink.href = url;
        document.body.appendChild(referLink);
        referLink.click();
    }
    else { window.location.replace(url); } // All other browsers
</script>
<!-- Credit goes to http://insider.zone/ -->
<!-- REDIRECTING ENDS -->
Nadeem Yasin picture
2012年10月30日
231

ただし、誰かがホームページにリダイレクトしたい場合は、次のスニペットを使用できます。

window.location = window.location.host

開発、ステージング、本番の3つの異なる環境があると便利です。

これらの単語をChromeコンソールまたはFirebugのコンソールに配置するだけで、このウィンドウまたはwindow.locationオブジェクトを探索できます。

Nikhil Agrawal picture
2013年12月23日
217

JavaScriptは、ブラウザのアドレスバーに表示されている現在のURLを取得および変更するための多くのメソッドを提供します。 これらのメソッドはすべて、WindowオブジェクトのプロパティであるLocationオブジェクトを使用します。 次のように、現在のURLを持つ新しいLocationオブジェクトを作成できます。

var currentLocation = window.location;

URLの基本構造

<protocol>//<hostname>:<port>/<pathname><search><hash>

enter image description here

  1. プロトコル-インターネット上のリソースにアクセスするために使用されるプロトコル名を指定します。 (HTTP(SSLなし)またはHTTPS(SSLあり))

  2. hostname-ホスト名は、リソースを所有するホストを指定します。 たとえば、www.stackoverflow.com。 サーバーは、ホストの名前を使用してサービスを提供します。

  3. ポート-インターネットまたはその他のネットワークメッセージがサーバーに到着したときに転送される特定のプロセスを認識するために使用されるポート番号。

  4. pathname-パスは、Webクライアントがアクセスしたいホスト内の特定のリソースに関する情報を提供します。 たとえば、stackoverflow.com /index.htmlです。

  5. query-クエリ文字列はパスコンポーネントの後に続き、リソースが何らかの目的で(たとえば、検索のパラメータとして、または処理されるデータとして)利用できる情報の文字列を提供します。

  6. hash-URLのアンカー部分には、ハッシュ記号(#)が含まれます。

これらのLocationオブジェクトプロパティを使用すると、これらすべてのURLコンポーネントにアクセスできます。

  1. hash -URLのアンカー部分を設定または返します。
  2. host -URLのホスト名とポートを設定または返します。
  3. hostname -URLのホスト
  4. href -URL全体を設定または返します。
  5. pathname -URLのパス名を設定または返します。
  6. ポート-Setsまたは戻りポート番号URLのサーバーの用途。
  7. protocol -URLの
  8. search -URLのクエリ部分を設定または返します

ここで、ページを変更したり、ユーザーを他のページにリダイレクトしたりする場合は、次のようにLocationオブジェクトのhrefプロパティを使用できます。

Locationオブジェクトのhrefプロパティを使用できます。

window.location.href = "http://www.stackoverflow.com";

ロケーションオブジェクトにもこれらの3つのメソッドがあります

  1. assign() -新しいドキュメントをロードします。
  2. reload() -現在のドキュメントを
  3. replace() -現在のドキュメントを新しいドキュメントに置き換えます

assign()メソッドとreplaceメソッドを使用して、これらのような他のページにリダイレクトすることもできます

location.assign("http://www.stackoverflow.com");

location.replace("http://www.stackoverflow.com");

assign()とreplace()の違い-replace()メソッドとassign()メソッド()の違いは、replace()がドキュメント履歴から現在のドキュメントのURLを削除することです。つまり、使用できません。元のドキュメントに戻るための「戻る」ボタン。 したがって、新しいドキュメントをロードする場合は、assign()メソッドを使用し、元のドキュメントに戻るオプションを指定します。

Alireza picture
2017年02月26日
208

基本的に、 jQueryは単なるJavaScriptフレームワークであり、この場合のリダイレクトなどの一部を実行するには、純粋なJavaScriptを使用できます。その場合、バニラJavaScriptを使用する3つのオプションがあります。

1)場所の置換を使用すると、ページの現在の履歴が置換されます。つまり、戻るボタンを使用して元のページに戻ることはできません。

window.location.replace("http://stackoverflow.com");

2)場所の割り当てを使用すると、履歴が保持され、戻るボタンを使用すると、元のページに戻ることができます。

window.location.assign("http://stackoverflow.com");

3)以前の方法のいずれかを使用することをお勧めしますが、これは純粋なJavaScriptを使用する3番目のオプションである可能性があります。

window.location.href="http://stackoverflow.com";

jQueryで関数を記述して処理することもできますが、これは1行の純粋なJavaScript関数であるためお勧めしません。また、すでにウィンドウスコープ内にいる場合は、ウィンドウなしで上記の関数をすべて使用できます(例: window.location.replace("http://stackoverflow.com");location.replace("http://stackoverflow.com");なる可能性があります

また、下の画像にそれらすべてを示しています。

location.replace location.assign