如何重定向到另一个网页?

如何使用 jQuery 或纯 JavaScript 将用户从一个页面重定向到另一页面?

答案

一个不只是简单地使用 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://stackoverflow.com");

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

警告:仅作为可能的解决方案提供此答案;它显然不是最好的解决方案,因为它需要 jQuery。相反,您更喜欢纯 JavaScript 解决方案。

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

重定向页面的标准 “香草” JavaScript 方法

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

或更简单地说:(因为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 刷新元标记的 noscript 部分也是一个很好的解决方案。我建议您使用此JavaScript 重定向工具创建重定向。它还具有 Internet Explorer 支持,以传递 HTTP 引荐来源网址。

没有延迟的示例代码如下所示:

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

但是,如果有人想重定向回主页,则可以使用以下代码段。

window.location = window.location.host

如果您具有三个不同的环境(如开发,登台和生产),这将很有帮助。

您可以通过将这些词放在 Chrome 控制台或Firebug的控制台中来探索该 window 或 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.stackoverflow.com。服务器使用主机名提供服务。

  3. 端口 - 端口号,用于识别 Internet 或其他网络消息到达服务器时将转发到的特定进程。

  4. pathname -路径提供有关 Web 客户端要访问的主机内特定资源的信息。例如,stackoverflow.com/index.html。

  5. 查询 - 查询字符串位于路径部分之后,并提供资源可用于某些目的的一串信息(例如,作为搜索的参数或要处理的数据)。

  6. hash-URL 的锚点部分,包括井号(#)。

使用这些 Location 对象属性,您可以访问所有这些 URL 组件

  1. 散列 -Sets 或返回 URL 的锚定部分。
  2. 主机 -Sets 或返回 URL 的主机名和端口。
  3. 主机名 - 设置或返回 URL 的主机名。
  4. HREF -Sets 或返回完整的 URL。
  5. pathname-设置或返回 URL 的路径名。
  6. 端口 - 设置或返回的端口号,服务器使用的 URL。
  7. protocol-设置或返回 URL 的协议。
  8. 搜索 -Sets 或返回 URL 的查询部分

现在,如果要更改页面或将用户重定向到其他页面,可以使用 Location 对象的href属性,如下所示

您可以使用 Location 对象的 href 属性。

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

定位对象也有这三种方法

  1. Assign() - 加载一个新文档。
  2. reload() - 重新加载当前文档。
  3. replace() - 用一个新文件替换当前文件

您可以使用 assign()和 replace 方法也可以重定向到此类其他页面

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

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

Assign()和 replace()有何 不同 - replace()方法和 Assign()方法()之间的区别在于 replace()从文档历史记录中删除当前文档的 URL,这意味着无法使用单击 “后退” 按钮可导航回到原始文档。因此,如果要加载新文档,并希望提供导航到原始文档的选项,请使用 assign()方法。

您也可以使用jQuery更改 location 对象的 href 属性

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

因此,您可以将用户重定向到其他 URL。

基本上, jQuery只是一个JavaScript框架,在这种情况下,您可以使用纯 JavaScript 来完成诸如重定向之类的操作 ,因此在这种情况下,您可以使用 Vanilla JavaScript 提供 3 个选项:

1)使用位置替换 ,这将替换页面的当前历史记录,这意味着无法使用 “ 后退”按钮返回到原始页面。

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

2)使用位置分配 ,这将为您保留历史记录,并使用返回按钮,您可以返回到原始页面:

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

3)我建议使用以前的方法之一,但这可能是使用纯 JavaScript 的第三个选项:

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

您也可以在 jQuery 中编写一个函数来处理它,但不建议这样做,因为它只是一行纯 JavaScript 函数,如果您已经在窗口范围内,也可以不使用窗口而使用上述所有函数,例如window.location.replace("http://stackoverflow.com");可能是location.replace("http://stackoverflow.com");

我也在下面的图片中展示了它们:

location.replace location.assign