遷移 - リダイレクト パラメータ 引継ぎ javascript




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

ページをリダイレクトする標準的な "バニラ" JavaScript方法:

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

リダイレクト時にHTTP_REFERERを失っているのでここにいる場合は、次のように読んでください:

次のセクションは、多くの安全対策の1つとしてHTTP_REFERERを使用HTTP_REFERERている人向けです(しかし、これは大きな保護手段ではありません)。 Internet Explorer 8以下を使用してInternet Explorer 8場合は、JavaScriptページリダイレクト(location.hrefなど)のいずれかの形式を使用すると、これらの変数が失われます。

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

HTTP_REFERER (URL貼り付け、セッションなど)に対するテストは、リクエストが正当なものかどうかを知るのに役立ちます。 注:コメント内のドループのリンクに記載されているように、これらのリファラーを回避/偽装する方法もあります)

簡単なクロスブラウザテストソリューション(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; 
    }
}

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


警告:この回答は単に解決策として提供されています。 それはjQueryを必要とするので 、明らかに最良の解決策ではありません 。 代わりに、純粋なJavaScriptソリューションを好む。

$(location).attr('href', 'http://.com')

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

jQueryは不要で、 window.location.replace(...)はHTTPリダイレクトをシミュレートするのに最適です。

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

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

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

例えば:

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

// similar behavior as clicking on a link
window.location.href = "http://.com";

*****オリジナルの質問があった - 「JQUERYを使用してリダイレクトする方法」、その答えがJQUERYになっている>>使い慣れた使用例*****

JavaScriptを使用したページにリダイレクトするには:

  window.location.href = "/contact/";

または、遅延が必要な場合:

setTimeout(function () {
  window.location.href = "/contact/";
}, 2000);   // Time in milliseconds

jQueryを使用すると、Webページから要素を簡単に選択できます。 ページ上で必要なものを見つけてから、jQueryを使って特殊効果を追加したり、ユーザーの行動に反応したり、選択した要素の内側または外側のコンテンツを表示したり隠したりすることができます。 これらのタスクはすべて、要素またはイベントの選択方法を知ることから始まります

     $('a,img').on('click',function(e){
         e.preventDefault();
         $(this).animate({
             opacity: 0 //Put some CSS animation here
         }, 500);
         setTimeout(function(){
           // OK, finished jQuery staff, let's go redirect
           window.location.href = "/contact/";
         },500);
     });

誰かが10000行のコードであるスクリプト/プラグインを書いたと想像してみてください。 さて、jQueryでは、このコードには1行か2行で接続できます。


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

var currentLocation = window.location;

URLの基本構造

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

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

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

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

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

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

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

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

  1. hash - URLのアンカー部分を設定または返します。
  2. host :URLのホスト名とポートを設定する、または設定状態を返す。
  3. hostname - URLのホスト名を取得または設定します。
  4. href - URL全体を設定するか返す。
  5. pathname - URLのパス名を取得または設定します。
  6. port - サーバがURLに使用するポート番号を設定する、または設定値を返します。
  7. protocol - URLのプロトコルを設定または返します。
  8. search - URLのクエリー部分を設定または返す

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

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

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

ロケーションオブジェクトには、次の3つのメソッドもあります

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

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

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

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

assign()とreplace()の違い - replace()メソッドとassign()メソッド()の違いは、replace()は現在のドキュメントのURLをドキュメント履歴から削除するということです。つまり、元の文書に戻るための「戻る」ボタン。 したがって、新しい文書を読み込みたい場合は、assign()メソッドを使用し、元の文書に戻るオプションを与えるようにします。

このようにjQueryを使用して位置オブジェクトのhrefプロパティを変更することもできます

$(location).attr('href',url);

したがって、ユーザーを別のURLにリダイレクトすることができます。


Javascript:

window.location.href='www.your_url.com';
window.top.location.href='www.your_url.com';
window.location.replace('www.your_url.com');

Jquery:

var url='www.your_url.com';
$(location).attr('href',url);
$(location).prop('href',url);//instead of location you can use window

jQueryを使わずに以下のようにすることができます:

window.location = "http://yourdomain.com";

jQueryだけが必要な場合は、次のようにすることができます。

$jq(window).attr("location","http://yourdomain.com");


#jQuery / JavaScriptを使用したHTMLページリダイレクト

次のコード例を試してください:

function YourJavaScriptFunction()
{
    var i = $('#login').val();
    if (i == 'login')
        window.location = "login.php";
    else
        window.location = "Logout.php";
}

完全なURLをwindow.location = "www.google.co.in";としたい場合はwindow.location = "www.google.co.in";


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

<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
    });
});

ここでは、時間遅延リダイレクトがあります。 あなたはあなたが望むものに遅延時間を設定することができます:

<!doctype html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Your Document Title</title>
    <script type="text/javascript">
        function delayer(delay) {
            onLoad = setTimeout('window.location.href = "http://www.google.com/"', delay);
        }
    </script>
</head>

<body>
    <script>
        delayer(8000)
    </script>
    <div>You will be redirected in 8 seconds!</div>
</body>

</html>

この行をコードに記述する必要があります:

$(location).attr("href","http://.com");

jQueryをお持ちでない場合は、JavaScriptを使用してください:

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

これはすべてのブラウザで動作します:

window.location.href = 'your_url';

これを行うには主に3つの方法がありますが、

window.location.href='blaah.com';
window.location.assign('blaah.com');

そして...

window.location.replace('blaah.com');

従来のリダイレクトでは、検索履歴にリダイレクトされる前に行ったページを保存しないため、最後の1つが最適です。 ただし、JavaScriptでタブを開くだけの場合は、上記のいずれかを使用できます。 1

編集: window接頭辞はオプションです。


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

window.location = window.location.host

開発、ステージング、および制作の3つの異なる環境がある場合に役立ちます。

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


つかいます:

// 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')

まず正しく書いてください。 アプリケーション内で、別のリンク用の別のリンクを探したい場合。 ここにコードです:

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

また、アプリケーション内のページをナビゲートする場合は、必要に応じてコードも用意されています。


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

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

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

<!-- 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 -->

次のようにjQueryでリダイレクトできます:

$(location).attr('href', 'http://yourPage.com/');

私はちょうどさらに新しいjQueryメソッドでこのばかげたことを更新しなければなりませんでした:

var url = 'http://www.fiftywaystoleaveyourlocation.com';
$(location).prop('href', url);




redirect