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


7723

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


147
我一直看到window.location = url; 和window.location.href = url; 它们有何不同?是吗 顺便说一句,我不知道window.location.replace(url)。真好
大卫·米勒

100
window.locationwindow.location.href在行为方面与相同。window.location返回一个对象。如果.href未设置,则window.location默认更改参数.href。结论:使用任何一种都可以。
猛禽

10
var url =“网站名称” $(location).attr('href',url);
疯狂的科学家

31
@MadScientist这是一种向后的方法。location对象不是HTML元素,使用jquery对象设置它似乎是错误的。当简单的JS代码如此简单时,为什么还要使用它呢?
Juan Mendes

1
为什么要重定向?不应提交登录表单?即使目标页面中没有逻辑,您仍然可以将表单提交到另一页面。
Dimt

Answers:


14802

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

// Another method for doing redirecting with JavaScript is this:
window.location = "https://stackoverflow.com";

78
如果提交按钮添加返回false; 也在您的功能内
Abhi 2012年

134
这个问题是关于javascript的,但值得注意的是,如果用户禁用了javascript,则可以将元刷新用作故障回复
Hoppe 2013年

22
@NicolòMartiniIf(IE)document.write(“”);
Jeff Noel

48
如果您已经在使用jQuery,请使用$(location).attr('href',url);window.location.href似乎在某些浏览器中的行为是不稳定的,实际上,在我的Firefox版本中,它完全无法正常工作。我听说设置window.location直接在IE版本中不起作用。
Noz

8
“更好”应该删除。如答案稍后所述,最佳解决方案是情境。OP不会问“我如何用Javascript模拟HTTP重定向...”
MadMaardigan

1684

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

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

63
这就是对问题的字面答案。如果您已经在使用Jquery并因此已经加载了Jquery,则它将提高带宽效率,并且使用快捷方式当然会更清楚
barrymac 2012年

27
更重要的是,有没有办法用抽象的jQuery做到这一点?这只是window.location.href = url;的包装。但是,如果jQuery具有某些功能,则window.location.href = url; 在当前环境(浏览器,OS等)中无法使用,jQuery核心可以弥补吗?
克里斯

271
以这种方式将jQuery强制加入方程式是荒谬和毫无意义的,尤其是因为window.location它不是元素,因此没有属性。
蒂姆·唐

10
我以某种方式怀疑这是否仍适用于.attr()实际设置属性的最新jQuery版本(即.setAttribute()
ThiefMaster

156
@deltaray这不是重定向的另一种方式,如上所述,它是对定位对象的毫无意义的包装,它甚至不是元素!这让我想起了i.stack.imgur.com/ssRUr.gif
JCM

675

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

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

或更简单地说:(因为window是Global)

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

60
脚注:将引荐来源网址作为一种安全措施进行检查是一个糟糕的解决方案。duckduckgo.com/?q=referrer+Spoofing
droope

如果引荐来源网址中有HTTP GET会话ID,则可以使用该ID对照会话进行有效性检查。
安德鲁·福克斯

@mcpDESIGNS确定要尝试使用location.assign吗?我在IE8中使用了我的应用程序,并且我不会丢失HTTP_REFERER标题。
Buzinas

至少在2012年,它无法正常工作,也许后来的IE8补丁修复了它-很好听!
Mark Pieszak-Trilon.io,

1
您对HTTP_REFERER的提及帮助我了解了window.open遇到的问题,并在这里找到了解决方案:stackoverflow.com/questions/7580613/…。顺便说一句,我在IE11中遇到了问题!
Dov Miller

427

有很多方法可以做到这一点。

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

8
window.navigate仅适用于旧版IE(Firefox / Chrome不支持此功能)。如果您想列举所有选项,请不要忘记document.location
Rob W

document.location = document.referrer; 请也将其添加到列表中。这不能像History.back那样工作,而是使页面再次刷新。
阿里·胡马云

.attr()在jQuery 3.0.0上不起作用。使用.val()代替。
Rivalus

4
@LéoLam这就是为什么有一个名为Google的搜索引擎的原因。:-)您可以在Google上相互搜索并找出不同之处。您不想随机选择一个。
我是最愚蠢的人

您也可以看到文档,developer.mozilla.org
en

330

这适用于所有浏览器:

window.location.href = 'your_url';

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

298

如果您对要执行的操作更具描述性,这将有所帮助。如果您尝试生成分页数据,则在执行此操作时有一些选择。您可以为要直接访问的每个页面生成单独的链接。

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

252

我也认为这location.replace(URL)是最好的方法,但是如果您想向搜索引擎通知您的重定向(它们不分析JavaScript代码来查看重定向),则应将rel="canonical"meta标签添加到您的网站。

添加一个带有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 -->

228

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

window.location = window.location.host

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

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


window.location.replace(window.location.protocol +“ //” + window.location.host)
莫阿拉2014年

13
甚至更简单: window.location = '/'
Iftah 2014年

213

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的查询部分

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

您可以使用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()方法。

您可以通过改变位置对象的href属性的jQuery也是这样

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

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


203

基本上,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


1
我建议也使用assign()over,href=因为在某些情况下后者对我来说无法正常工作。
marsze


169

在开始之前,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。如果您确实使用了允许用户返回到重定向页面的选项,请记住,当您进入重定向页面时,它将重定向您。因此,在选择重定向选项时要考虑到这一点。在仅用户执行操作时页面仅重定向的情况下,将页面包含在后退按钮历史记录中就可以了。但是,如果页面自动重定向,则应使用replace,以便用户可以使用后退按钮而不必强制返回到重定向发送的页面。

您还可以按照以下说明使用元数据来运行页面重定向。

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>

如果将这两个页面示例结合在一起,则会产生一个重新路由的婴儿循环,这将确保您的用户永远不再希望再次使用您的网站。


5
我通过说不需要jQuery来解决他对jQuery的请求。JQuery有很多非常有用的JavaScript快捷方式,但是不需要任何用于重定向的快捷方式。JQuery只是JavaScript。而已。调用重定向的常规方法将使用jQuery与他的函数一起使用。
Patrick W. McMahon 2015年

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

145

您可以在没有jQuery的情况下做到这一点:

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

如果只需要jQuery,则可以这样做:

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

jQuery可以说是一个更好的主意,因为它可以抽象出将来的浏览器更改/弃用
Epirocks

@Epirocks如果jQuery中为此设计了一个API,那可能是一个正当的理由(尽管怀疑该API是否会更改),但是这里的示例只是滥用了jQuery的功能,您可以在其中包装非DOM对象,并且有些方法仍然有效。
1

“某些方法仍然可以使用”这一事实正是我抽象化的意思。是的,您可以在没有JQuery的情况下做到这一点,但是除了JQuery之外,您也可以做任何事情。
Epirocks

144

这适用于jQuery:

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

仅仅因为它有效,并不意味着您应该这样做。这是关于设置的毫无意义的间接说明window.location
1

89

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

尝试以下示例代码:

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


“使用jQuery”是um,不准确。使用完整URL的示例将不起作用,因为这不是完整URL。没有协议,因此它将被解释为相对URL。
1j01年

80

您需要将此行放入代码中:

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

如果您没有jQuery,请使用JavaScript:

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

80

原始问题: “如何使用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,您只需一两行就可以连接到此代码。


Javascript标头:是否可以以秒为单位进行时间设置?
PythonMaster202 '19

79

因此,问题是如何制作重定向页面,而不是如何重定向到网站?

您只需要为此使用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://stackoverflow.com

而且,如果您转到该链接,它将自动将您重定向到stackoverflow.com

链接到文档

这就是您使用JavaScript 创建简单重定向页面的方式

编辑:

还有一件事要注意。我已经添加window.location.replace了代码,因为我认为它适合重定向页面,但是,您必须知道,在使用时window.location.replace会被重定向,当您在浏览器中按“后退”按钮时,它不会返回到重定向页面,它将返回上一页,看看这个小演示。

例:

流程:存储主页 => 将页面重定向到Google => Google

在Google上时:google => 浏览器中的后退按钮 => 存放主页

因此,如果这符合您的需求,那么一切都会很好。如果要在浏览器历史记录中包括重定向页面,请替换此页面

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

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

74

在点击功能上,只需添加:

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


57

不需要jQuery。你可以这样做:

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

就这么简单!

发起HTTP请求的最佳方法是使用document.loacation.href.replace('URL')


52

首先正确编写。您要在应用程序中导航至另一个链接,而在应用程序中导航至另一个链接。这是代码:

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

而且,如果您想浏览应用程序中的页面,那么如果需要,我也有代码。


52

您可以像这样在jQuery中重定向:

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

45

在JavaScript和jQuery中,我们可以使用以下代码将一个页面重定向到另一页面:

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

45

ECMAScript 6 + jQuery,85字节

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

请别杀了我,这是个玩笑。开个玩笑。这是个玩笑。

从某种意义上说,这确实“提供了问题的答案”,因为它要求“使用jQuery”解决方案,在这种情况下,它必须以某种方式将其强制加入方程式。

Ferrybig显然需要讲出这个笑话(仍然是在开玩笑,我敢肯定评论表单上的选择有限),所以事不宜迟:

其他答案是attr()locationwindow对象上不必要地使用jQuery 。

这个答案也滥用它,但是以一种更荒谬的方式。与其使用它来设置位置,不如使用它来attr()检索用于设置位置的函数。

jQueryCode即使没有任何jQuery,该函数也被命名,并且调用函数somethingCode太可怕了,尤其是当某些东西甚至不是语言时。

“ 85字节”是对Code Golf的引用。打高尔夫球显然不是您应该在标准打高尔夫球之外做的事情,而且显然,这个答案实际上并不是打高尔夫球。

基本上,畏缩。


45

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

1
是否有理由将url作为变量存储在jQuery中,而不是使用Vanilla?
ESR 2017年

43

使用JavaScript:

方法1:

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

方法2:

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

使用jQuery:

方法1:$(位置)

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

方法2:可重用函数

jQuery.fn.redirectTo = function(url){
    window.location.href = url;
}

jQuery(window).redirectTo("http://google.com");

41

这是一个延时重定向。您可以将延迟时间设置为所需的任何值:

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

5
最好这样做:setTimeout(function(){window.location.href =“ google.com ”},延迟);
dikkini 2014年

39

有三种主要的方法可以做到这一点,

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

和...

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

对于传统的重定向,最后一个最好,因为在重定向到搜索历史记录之前,它不会保存您访问过的页面。但是,如果您只想使用JavaScript打开选项卡,则可以使用上述任何选项。1个

编辑:window前缀是可选的。

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.