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


Answers

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

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

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




これを行うには主に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.href = "The URL where you want to redirect";
$('#id').click(function(){
    window.location.href = "http://www.google.com";
});



これはjQueryで動作します:

$(window).attr("location", "http://google.fr");



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

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



つかいます:

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



#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";




*****オリジナルの質問があった - 「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行で接続できます。




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

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



ECMAScript 6 + jQuery、85バイト

$({jQueryCode:(url)=>location.replace(url)}).attr("jQueryCode")("http://example.com")

私を殺さないでください、これは冗談です。 それは冗談だ。 これは冗談です。

これは、「質問への答えを提供する」という意味で、「jQueryを使用する」というソリューションを求めていました。この場合は、何らかの形で方程式に強制する必要があります。

Ferrybigは明らかに冗談が説明されている必要があります(まだ冗談ですが、レビューフォームにはオプションが限られていると確信しています)。

その他の答えは、不必要にlocationまたはwindowオブジェクトにjQueryのattr()していlocation

この答えはまた、それを乱用しますが、よりばかげたやり方です。 これを使用して場所を設定する代わりに、 attr()を使用して場所を設定する関数を取得します。

この関数はjQueryCodeという名前が付けられていますが、 somethingCode jQueryはありませんが、関数somethingCodeを呼び出すのは恐ろしいことです。

"85バイト"はコードゴルフへの参照です。 ゴルフは明らかにコードゴルフの外で行うべきことではなく、さらにこの答えは実際にはゴルフではありません。

基本的には、うんざりします。







var url = 'asdf.html';
window.location.href = url;



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

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

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




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

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

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

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