题 如何重定向到其他网页?


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


7737
2018-02-02 12:54


起源


我一直看到window.location = url;和window.location.href = url;他们有什么不同?是吗?顺便说一句,我不知道window.location.replace(url)。尼斯。 - David M. Miller
window.location 是相同的 window.location.href,就行为而言。 window.location 返回一个对象。如果 .href 未设定, window.location 默认为更改参数 .href。结论:使用任何一个都没问题。 - Raptor
var url =“网站名称”$(位置).attr('href',url); - Mad Scientist
@MadScientist这是一种向后的方式。 location对象不是HTML元素,使用jquery对象设置它似乎是错误的。当直接JS代码如此简单时,为什么要使用它? - Juan Mendes
你为什么要重定向?登录表格不应该提交?即使目标页面中没有逻辑,您仍然可以将表单提交到另一个页面。 - Dimt


答案:


一个不是简单地使用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";

12949
2018-02-03 04:24



如果提交按钮添加返回false;也在你的功能里面 - Abhi
问题是关于javascript的具体,但值得注意的是,如果用户禁用了javascript,则可以将元刷新用作故障恢复 - Hoppe
@NicolòMartiniIf(IE)document.write(“”); - Jeff Noel
@NicolòMartini如果你想看一下,我发布了一种不丢失REFERRER的方法! - Mark Pieszak - DevHelp.Online
如果您已经在使用jQuery,请使用 $(location).attr('href',url);。 window.location.href 在某些浏览器中似乎有不稳定的行为,事实上,它在我的Firefox版本中不起作用。我听说过设置 window.location 直接不在IE版本中工作。 - Noz


警告: 这个答案仅作为可能的解决方案提供;很明显  最好的解决方案,因为它需要jQuery。相反,更喜欢纯JavaScript解决方案。

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

1473
2017-10-28 16:35



这就是问题的字面答案。如果您已经在使用Jquery并因此已经加载了它,那么它将提高带宽效率,当然使用快捷方式更清晰 - barrymac
更重要的是,有没有办法用jQuery做到这一点,这是多么抽象?这只是window.location.href = url的包装器;但是如果jQuery有一些功能,如果window.location.href = url;是不是在当前的环境(浏览器,操作系统等)工作jQuery核心可以补偿? - Chris
以这种方式强迫jQuery进入等式是荒谬和毫无意义的,尤其是从那以后 window.location 不是元素,因此没有属性。 - Tim Down
@CoffeeAddict,2岁的评论,但请告诉我如何 location.href = 'http://stackoverflow.com'; 这里答案比其他答案更冗长?即使你拿走变量,使用jQuery仍然会更加冗长和更多的字符。 - rlemon
@deltaray这是 不 另一种重定向方式,如上所述,它是位置对象周围无意义的包装器,甚至不是元素!这让我想起了 i.stack.imgur.com/ssRUr.gif - JCM


标准的“vanilla”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粘贴,会话等) 能够 有助于说明请求是否合法。 注意: 还有办法解决/欺骗这些推荐人,正如评论中的droop链接所指出的那样)


简单的跨浏览器测试解决方案(回退到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; 
    }
}

509
2017-07-27 14:41



脚注:检查引荐来源作为安全措施是一个糟糕的解决方案。 duckduckgo.com/?q=referrer+spoofing - droope
如果引用URL中有HTTP GET会话ID,则可以使用它来检查会话中的有效性。 - Andrew Fox
@mcpDESIGNS你确定你已经尝试过使用了 location.assign?我在我的应用程序中使用IE8,我不会丢失 HTTP_REFERER 头。 - Buzinas
至少在2012年它没有工作,也许后来的IE8修补程序修复它 - 虽然听起来很好! - Mark Pieszak - DevHelp.Online


使用:

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

349
2018-01-28 04:28



window.navigate 是旧的IE浏览器(Firefox / Chrome不支持此功能)。如果您想列举所有选项,请不要忘记 document.location。 - Rob W
这没有解释 什么 一点都不有人应该选择什么?从列表中随机选择一个?此外,这对现有答案有何影响? - Léo Lam
这个答案是 目前在meta讨论过 - Bergi
@LéoLam这就是为什么有一个名为Google的搜索引擎。 :-)您可以在Google上搜索每一个并找到差异。你不想随意挑选一个。 - I am the Most Stupid Person
@IamtheMostStupidPerson完全是我的观点。答案是没用的。 - Léo Lam


这适用于每个浏览器:

window.location.href = 'your_url';

269
2017-10-22 23:45



你也可以这样做 document.location.replace(redirectURL) 如果您不希望第一页在浏览器历史记录中 - jazzcat


如果您对自己想做的事情有一点描述性,那将会有所帮助。如果您尝试生成分页数据,则有一些选项可用于执行此操作。您可以为希望能够直接访问的每个页面生成单独的链接。

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

253
2018-02-02 13:18





我也这么认为 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 -->

215
2018-04-25 10:12





但如果有人想重定向回主页,那么他可能会使用以下代码段。

window.location = window.location.host

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

您只需将这些单词放在Chrome控制台或中,即可浏览此窗口或window.location对象 萤火的控制台。


191
2017-10-30 12:15



window.location.replace(window.location.protocol +“//”+ window.location.host) - moala
更简单: window.location = '/' - Iftah
Iftah - 这取决于“基础”元标记。 - Rob Quist


JavaScript为您提供了许多方法来检索和更改浏览器地址栏中显示的当前URL。所有这些方法都使用Location对象,它是Window对象的属性。您可以创建一个具有当前URL的新Location对象,如下所示。

var currentLocation = window.location;

URL的基本结构

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

enter image description here

  1. 协议 - 指定用于访问Internet上资源的协议名称。 (HTTP(不使用SSL)或HTTPS(使用SSL))

  2. hostname - 主机名指定拥有该资源的主机。例如,www.stackoverflow.com。服务器使用主机名提供服务。

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

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

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

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

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

  1. 哈希    - 设置或返回URL的锚点部分。
  2. 主办   -Sets 或返回URL的主机名和端口。
  3. 主机名    - 或者 返回URL的主机名。
  4. HREF    - 设置或返回整个 URL。
  5. 路径    - 设置或返回URL的路径名。
  6. 港口  - 设置或返回服务器用于URL的端口号。
  7. 协议    - 设置或返回URL的协议。
  8. 搜索   -Sets 或返回URL的查询部分

现在如果您想要更改页面或将用户重定向到其他页面,您可以使用 href 像这样的Location对象的属性

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

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

位置对象 也有这三种方法

  1. 分配()  - 加载新文档。
  2. 重装()  - 重新加载当前文档。
  3. 更换()  - 用新的文档替换当前文档

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

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

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

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


183
2017-12-23 13:35





应该只能设置使用 window.location

例:

window.location = "https://stackoverflow.com/";

这是关于这个主题的过去的帖子:

如何重定向到其他网页?


166
2018-02-16 14:42



它可能有效,但我不确定这是否是正确的方法。我没有看到支持这一点的文档。它可能会导致程序员陷入糟糕的编程习惯。 - Jaider