[Javascript] 我如何重定向到另一個網頁?


Answers

警告:此答案僅作為可能的解決方案提供; 它顯然不是最好的解決方案,因為它需要jQuery。 相反,更喜歡純粹的JavaScript解決方案。

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

如何使用jQuery或純JavaScript將用戶從一個頁面重定向到另一個頁面?




如果你對你想要做的事情有更多的描述,這將會有所幫助。 如果您正在嘗試生成分頁數據,那麼您在執行此操作時會遇到一些選項。 您可以為每個想要直接獲取的頁面生成單獨的鏈接。

<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的用武之地。您要做的是為每個與不同頁面對應的錨標籤添加一個點擊處理程序。 這個點擊處理程序會調用一些jQuery代碼,並通過AJAX獲取下一頁,並用新數據更新表格。 下面的例子假設您有一個返回新頁面數據的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.href = "http://www.google.com";

如果你想在你的應用程序中導航頁面,那麼我也有代碼,如果你想。




這是一個時間延遲重定向。 您可以將延遲時間設置為任何你想要的:

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



有三種主要方式可以做到這一點,

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

和...

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

對於傳統的重定向,最後一個是最好的,因為它不會保存您在搜索歷史中重定向之前所到達的頁面。 但是,如果您只想使用JavaScript打開選項卡,則可以使用上述任何一項。 1

編輯: window前綴是可選的。




*****原始問題 - “如何重新使用JQUERY”,答案實現JQUERY >>完全使用案例*****

只需重定向到使用JavaScript的頁面:

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

或者如果您需要延遲:

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

jQuery允許您輕鬆地從網頁中選擇元素。 您可以在頁面上找到任何您想要的內容,然後使用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你可以用一兩行連接到這個代碼。




在您的點擊功能上,只需添加:

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



ECMAScript 6 + jQuery,85個字節

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

請不要殺了我,這是一個笑話。 這是一個笑話。 這是個玩笑。

這確實“提供了對這個問題的答案”,因為它要求“使用jQuery”的解決方案,在這種情況下,這需要以某種方式強制它進入方程。

Ferrybig顯然需要解釋這個笑話(仍然在開玩笑,我確信評論表上的選項很有限),所以沒有多餘的道理:

其他答案是不必要地在locationwindow對像上使用jQuery的attr()

這個答案也濫用了它,但是以一種更荒謬的方式。 而不是使用它來設置位置,它使用attr()來檢索設置位置的函數。

該函數被命名為jQueryCode即使沒有任何關於它的jQuery,並且調用某個函數somethingCode是非常糟糕的,特別是當某些東西甚至不是語言時。

“85字節”是Code Golf的參考。 顯然,打高爾夫不是高爾夫之外你應該做的事情,而且這個答案顯然不是高爾夫。

基本上,畏縮。







但是如果有人想重定向回主頁,那麼他可以使用下面的代碼片段。

window.location = window.location.host

如果您有三種不同的環境,例如開發,分期和生產,這將會很有幫助。

您只需將這些文字放入Chrome控制台或Firebug的控制台即可瀏覽此窗口或window.location對象。




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



你需要把這行代碼放在你的代碼中:

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

如果您沒有jQuery,請使用以下JavaScript:

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



使用:

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



#HTML頁面重定向使用jQuery / JavaScript

試試這個例子代碼:

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