javascript - 如何重定向到另一個網頁?


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




Answers


一個不會簡單地使用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://.com");

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



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

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



標準的“香草”JavaScript重定向頁面的方式:

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

如果因為在重定向時丟失 HTTP_REFERER而來到這裡,請繼續閱讀:

以下部分針對那些使用HTTP_REFERER作為許多安全措施之一(儘管這不是一個很好的保護措施)。 如果您使用的是Internet Explorer 8或更低版本,則在使用任何形式的JavaScript頁面重定向(location.href等)時,這些變量會丟失。

下面我們將實現一個替代IE8&更低,這樣我們不會失去HTTP_REFERER。 否則,你幾乎總是可以簡單地使用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; 
    }
}



使用:

// 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 = 'your_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
    });
});



我也認為location.replace(URL)是最好的方法,但是如果你想通知搜索引擎你的重定向(他們不分析JavaScript代碼來看重定向),你應該添加rel="canonical"元標記到您的網站。

添加一個帶有HTML刷新元標記的無腳本部分也是一個很好的解決方案。 我建議你使用這個JavaScript重定向工具來創建重定向。 它還具有Internet Explorer支持來傳遞HTTP引用。

示例代碼沒有延遲看起來像這樣:

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



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

window.location = window.location.host

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

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




JavaScript提供了許多方法來檢索和更改瀏覽器地址欄中顯示的當前URL。 所有這些方法都使用Location對象,它是Window對象的一個屬性。 您可以創建一個具有當前URL的新的Location對象,如下所示。

var currentLocation = window.location;

URL的基本結構

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

  1. 協議 - 指定用於訪問Internet上資源的協議名稱。 (HTTP(不帶SSL)或HTTPS(帶SSL))

  2. 主機名 - 主機名指定擁有資源的主機。 例如,www..com。 服務器使用主機的名稱提供服務。

  3. 端口 - 端口號,用於識別Internet或其他網絡消息到達服務器時要轉發到的特定進程。

  4. 路徑名 - 該路徑提供有關Web客戶端要訪問的主機內的特定資源的信息。 例如,.com/index.html。

  5. 查詢 - 查詢字符串跟隨路徑組件,並提供資源可用於某種目的(例如,作為搜索參數或要處理的數據)的一串信息。

  6. 散列 - URL的錨點部分包含散列符號(#)。

通過這些Location對象屬性,您可以訪問所有這些URL組件

  1. 散列值 - 設置或返回URL的錨點部分。
  2. 主機 - 設置或返回URL的主機名和端口。
  3. hostname - 設置或返回URL的主機名。
  4. href - 設置或返回整個網址。
  5. 路徑名 - 設置或返回URL的路徑名稱。
  6. 端口 - 設置或返回服務器用於URL的端口號。
  7. 協議 - 設置或返回URL的協議。
  8. 搜索 - 設置或返回URL的查詢部分

現在,如果您想更改頁面或將用戶重定向到其他頁面,則可以使用Location對象的href屬性,如下所示

您可以使用Location對象的href屬性。

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

位置對像也有這三個方法

  1. assign() - 加載一個新文檔。
  2. reload() - 重新加載當前文檔。
  3. 替換() - 用新的替換當前文檔

您可以使用assign()並替換方法來重定向到其他頁面

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

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

如何分配()和替換()不同 - replace()方法和assign()方法()之間的區別是,replace()從文檔歷史記錄中刪除當前文檔的URL,意味著它是不可能使用“返回”按鈕導航回到原始文檔。 所以,如果你想加載一個新的文檔,那麼使用assign()方法,並且會給出選項導航回原始文檔。

你也可以像這樣使用jQuery來更改位置對象的href屬性

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

因此,您可以將用戶重定向到其他網址。







在我開始之前,jQuery是一個用於DOM操作的JavaScript庫。 所以你不應該使用jQuery來進行頁面重定向。

來自Jquery.com的引用:

雖然jQuery可能在較老的瀏覽器版本中運行時沒有大問題,但是我們並不主動測試jQuery,通常也不會修正可能出現在其中的錯誤。

它被發現在這裡: https//jquery.com/browser-support/

所以jQuery不是一個全面的,全部的向後兼容的解決方案。

以下使用原始JavaScript的解決方案適用於所有瀏覽器,並且已經很長時間達到標準,所以您不需要任何庫來支持跨瀏覽器。

3000毫秒後,此頁面將重定向到Google

<!DOCTYPE html>
<html>
    <head>
        <title>example</title>
    </head>
    <body>
        <p>You will be redirected to google shortly.</p>
        <script>
            setTimeout(function(){
                window.location.href="http://www.google.com"; // The URL that will be redirected too.
            }, 3000); // The bigger the number the longer the delay.
        </script>
    </body>
</html>

不同的選項如下:

window.location.href="url"; // Simulates normal navigation to a new page
window.location.replace("url"); // Removes current URL from history and replaces it with a new URL
window.location.assign("url"); // Adds new URL to the history stack and redirects to the new URL

window.history.back(); // Simulates a back button click
window.history.go(-1); // Simulates a back button click
window.history.back(-1); // Simulates a back button click
window.navigate("page.html"); // Same as window.location="url"

當使用替換時,後退按鈕不會回到重定向頁面,就好像它從未在歷史中一樣。 如果您希望用戶能夠返回重定向頁面,請使用window.location.hrefwindow.location.assign 。 如果您確實使用允許用戶返回重定向頁面的選項,請記住,當您進入重定向頁面時,它會將您重定向回。 所以選擇重定向選項時要考慮到這一點。 在頁面只有在用戶完成操作後重定向的情況下,後退按鈕歷史中的頁面才可以。 但是,如果頁面自動重定向,那麼您應該使用替換,以便用戶可以使用後退按鈕,而不會強制回到重定向發送的頁面。

您也可以使用元數據運行頁面重定向,如下所示。

META刷新

<meta http-equiv="refresh" content="0;url=http://evil.com/" />

META位置

<meta http-equiv="location" content="URL=http://evil.com" />

基地劫持

<base href="http://evil.com/" />

可以在這個頁面找到更多的方法來重定向你不知情的客戶端到他們不希望去的頁面(其中沒有一個依賴於jQuery):

https://code.google.com/p/html5security/wiki/RedirectionMethods

我也想指出,人們不喜歡隨機重定向。 只有在絕對需要時才會重定向人員。 如果你開始隨機重定向,他們將永遠不會再去你的網站。

下一部分是假設的:

您也可能會被報告為惡意網站。 如果發生這種情況,那麼當用戶點擊您網站的鏈接時,用戶瀏覽器可能會警告他們您的網站是惡意的。 如果人們在您的網站上報告不好的體驗,搜索引擎可能會開始降低您的評分。

請查看Google網站管理員指南有關重定向的信息: https//support.google.com/webmasters/answer/2721217?hl = zh_CN&ref_topic = 6001971

這是一個有趣的小頁面,將您踢出頁面。

<!DOCTYPE html>
<html>
    <head>
        <title>Go Away</title>
    </head>
    <body>
        <h1>Go Away</h1>
        <script>
            setTimeout(function(){
                window.history.back();
            }, 3000);
        </script>
    </body>
</html>

如果將兩個頁面示例組合在一起,您將會有一個重新路由的嬰兒循環,這將保證您的用戶永遠不會想再次使用您的網站。




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



你可以做到這一點,沒有jQuery:

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

如果你只想要jQuery,那麼你可以這樣做:

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



這適用於jQuery:

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



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




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

你只需要使用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;



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

window.location.href = "The URL where you want to redirect";
$('#id').click(function(){
    window.location.href = "http://www.google.com";
});



基本上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");

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







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

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

這很容易!

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




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

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

如果你沒有jquery,那就用javascript去吧

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



先寫好。 您希望在應用程序中導航,以便從您的應用程序的另一個鏈接進行另一個鏈接 這裡是代碼:

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

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




你可以像這樣在jQuery中重定向:

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



只是重定向到一個頁面:

  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和jQuery中,我們可以使用下面的代碼將一個頁面重定向到另一個頁面:

window.location.href="http://google.com";
window.location.replace("page1.html");



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的參考。 高爾夫運動顯然不是高爾夫之外你應該做的事情,而且這個答案顯然不是高爾夫運動。

基本上,畏縮。




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

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



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

var url = 'http://www.fiftywaystoleaveyourlocation.com';
$(location).prop('href', 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



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

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

和...

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

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

編輯: window前綴是可選的。