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


Answers

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

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

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




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

window.location = window.location.host

如果你有三個不同的環境,如開發,分期和生產,這將是有幫助的。

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




只是重定向到一個頁面:

  window.location.href = "/destination.html";

或者,如果您需要延遲:

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

jQuery允許您輕鬆地從網頁中選擇元素。 您可以在頁面中找到任何您想要的內容,然後使用jQuery添加特殊效果,對用戶操作做出反應,或者在所選元素內部或外部顯示和隱藏內容。 所有這些任務從知道如何選擇一個元素開始

function redirect () {
    $('selection').animate({
        marginLeft: 100px; //Put some CSS animation here
    }, 500, function () {
      // OK, finished jQuery staff, let's go redirect
      window.location.href = "/destination.html";
})

想像一下,有人寫了一個腳本/插件是10000行的代碼? 那麼,使用jQuery,你可以用一兩行連接到這個代碼。







所以,問題是如何做一個重定向頁面,而不是如何重定向到一個網站?

你只需要使用JavaScript來做到這一點。 以下是一些可以創建動態重定向頁面的小代碼。

<script>
    var url = window.location.search.split('url=')[1]; // Get the URL after ?url=
    if( url ) window.location.replace(url);
</script>

所以說,你只需把這個片段放到你網站上的redirect/index.html文件中就可以像這樣使用它。

http://www.mywebsite.com/redirect?url=http://.com

如果你去那個鏈接,它會自動將你重定向到.com

鏈接到文檔

這就是你如何用JavaScript創建一個簡單的重定向頁面

編輯:

還有一件事要注意。 我已經在我的代碼中添加了window.location.replace ,因為我認為它適合重定向頁面,但是,您必須知道,當使用window.location.replace並且重定向時,當您按下瀏覽器中的後退按鈕時,將不會回到重定向頁面,它會回到之前的頁面,看看這個小演示的東西。

例:

這個過程: store home => 重定向頁面到google => google

當在谷歌: 谷歌 => 後退按鈕瀏覽器 => 存儲在家中

所以,如果這符合你的需求,那麼一切都應該是好的。 如果您想在瀏覽器歷史記錄中包含重定向頁面,請將其替換

if( url ) window.location.replace(url);

if( url ) window.location.href = url;



這適用於jQuery:

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



有三種主要的方法來做到這一點,

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

和...

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

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

編輯: window前綴是可選的。




基本上jQuery是一個JavaScript庫,為了做一些像重定向這樣的事情,你可以使用純JavaScript,所以在這種情況下,你有3個選擇使用香草JavaScript:

1)使用位置替換 ,這將取代當前頁面的歷史記錄,意味著不可能使用後退按鈕返回到原始頁面。

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

2)使用位置分配 ,這將保持你的歷史和使用後退按鈕,你可以回到原來的頁面:

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

3)我建議使用以前的方法之一,但這可能是使用純JavaScript的第三種選擇:

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

你也可以在jQuery中編寫一個函數來處理它,但不建議這樣做,因為它只有一行純JavaScript函數,如果你已經在窗口範圍內,你也可以使用上面所有的函數而不需要窗口,例如window.location.replace("http://.com"); 可以location.replace("http://.com");

另外我在下面的圖片上展示他們:




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



jQuery是不需要的。 你可以這樣做:

window.open("URL","_self","","")

這很容易!

發起HTTP請求的最好方法是使用document.loacation.href.replace('URL')




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

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

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




我只是用另一個更新的jQuery方法來更新這個荒謬:

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



使用:

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



ECMAScript 6 + jQuery,85個字節

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

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

這樣做“提供了一個問題的答案”,因為它提出了一個“使用jQuery”的解決方案,在這種情況下需要以某種方式強迫它進入方程式。

Ferrybig顯然需要這個笑話解釋(仍然在開玩笑,我敢肯定評論表上的選項是有限的),所以不要著急:

其他答案是使用jQuery的attr()不必要的locationwindow對象。

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

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

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

基本上,畏縮。