javascript js重定向url jquery重定向 - 如何重定向到其他网页?




15 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://stackoverflow.com");

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

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




标准的“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; 
    }
}



这适用于每个浏览器:

window.location.href = 'your_url';



我还认为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 -->



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

var currentLocation = window.location;

URL的基本结构

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

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

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

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

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

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

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

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

  1. hash -Set或返回URL的锚点部分。
  2. host - 设置或返回URL的主机名和端口。
  3. hostname - 设置或返回URL的主机名。
  4. href - 设置或返回整个URL。
  5. pathname - 设置或返回URL的路径名。
  6. port - 设置或返回服务器用于URL的端口号。
  7. protocol - 设置或返回URL的协议。
  8. search - 设置或返回URL的查询部分

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

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

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

Location Object也有这三种方法

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

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

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

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

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

您也可以使用jQuery更改位置对象href属性

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

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




基本上jQuery只是一个JavaScript框架 ,在这种情况下做一些重定向等事情,你可以使用纯JavaScript,所以在这种情况下你有3个选项使用vanilla 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).attr("location", "http://google.fr");



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

您只需要使用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并且你被重定向时,当你在浏览器中按下后退按钮时它不会回到重定向页面,它会回到之前的页面,看看这个小小的演示内容。

例:

过程: 将home home => 重定向页面改为google => google

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



试试这个:

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

示例的代码段




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

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



使用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



ECMAScript 6 + jQuery,85字节

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

请不要杀我,这是个玩笑。 这是个玩笑。 这是个玩笑。

这确实“提供了问题的答案”,因为它要求“使用jQuery”的解决方案,在这种情况下需要以某种方式强制它进入等式。

Ferrybig显然需要解释这个笑话(仍在开玩笑,我确信评论表上的选项有限),所以不用多说:

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

这个答案也滥用它,但是更加荒谬。 它使用attr()来检索设置位置的函数,而不是使用它来设置位置。

该函数被命名为jQueryCode即使它没有关于它的jQuery,并且调用函数somethingCode是可怕的,特别是当某些东西甚至不是一种语言时。

“85字节”是对Code Golf的引用。 高尔夫显然不是你应该在代码高尔夫之外做的事情,而且这个答案显然不是高尔夫球。

基本上,畏缩。




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

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

和...

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

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

编辑: window前缀是可选的。




Related