如何重定向到其他网页?

如何使用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') 

标准的“vanilla”JavaScript方式重定向页面:

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


如果你在这里是因为你在重定向时丢失了 HTTP_REFERER,请继续阅读:


以下部分适用于那些使用HTTP_REFERER作为许多安全措施之一的人(虽然它不是一个很好的保护措施)。 如果您使用的是Internet Explorer 8或更低版本,则在使用任何forms的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 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'; 

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

 1 2 3 ... 

请注意,示例中的当前页面在代码和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引用者。

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

            

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

 window.location = window.location.host 

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

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

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

 var currentLocation = window.location; 

URL的基本结构

 //:/ 

在此处输入图像描述

  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. 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.stackoverflow.com"; 

Location Object也有这三种方法

  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更改位置对象href属性

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

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

应该只能使用window.location进行设置。

例:

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

这是关于这个主题的过去的post:

如何重定向到其他网页?

基本上jQuery只是一个JavaScript框架 ,在这种情况下做一些重定向等事情,你可以使用纯JavaScript,所以在这种情况下你有3个选项使用vanilla JavaScript:

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

在开始之前,jQuery是一个用于DOM操作的JavaScript库。 所以你不应该使用jQuery进行页面重定向。

来自Jquery.com的报价:

虽然jQuery可能在旧的浏览器版本中没有出现重大问题,但我们并不主动测试它们中的jQuery,并且通常不会修复可能出现在它们中的错误。

它在这里找到: https : //jquery.com/browser-support/

因此,jQuery并不是一种能够实现向后兼容的最终解决方案。

以下使用原始JavaScript的解决方案适用于所有浏览器并且已经标准很长时间,因此您不需要任何库来支持跨浏览器。

此页面将在3000毫秒后重定向到Google

    example   

You will be redirected to google shortly.

不同的选项如下:

 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位置

  

基地劫持

  

可以在此页面上找到更多将您的毫无疑问的客户端重定向到他们可能不希望访问的页面的方法(其中一个不依赖于jQuery):

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

我还想指出,人们不喜欢被随机重定向。 仅在绝对需要时重定向人员。 如果您开始随机重定向人员,他们将永远不会再次访问您的网站。

下一部分是假设的:

您也可能被报告为恶意网站。 如果发生这种情况,那么当用户点击指向您网站的链接时,用户浏览器可能会警告他们您的网站是恶意的。 如果人们报告您网站上的不良体验,搜索引擎可能会开始降低您的评分。

请查看有关重定向的Google网站站长指南: https : //support.google.com/webmasters/answer/2721217?hl = zh-CN&ref_topic = 6001971

这是一个有趣的小页面,可以让你离开页面。

    Go Away   

Go Away

如果您将两个页面示例组合在一起,您将拥有一个婴儿循环重新路由,这将保证您的用户永远不会再想要再次使用您的网站。

 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即可。 这是一些将创建动态重定向页面的小代码。

  

所以说你只需把这个片段放到你网站上的redirect/index.html文件中就可以这样使用了。

http://www.mywebsite.com/redirect?url=http://stackoverflow.com

如果您转到该链接,它将自动将您重定向到stackoverflow.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; 

您需要在代码中添加以下行:

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

如果您没有jQuery,请使用以下命令运行JavaScript:

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

在您的点击function上,只需添加:

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

*****原始问题 – “如何重新使用JQUERY”,HANS THE ANSWER IMPLEMENTS 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,您只需一两行即可连接到此代码。

试试这个:

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

示例的代码段 。

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

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

就这么简单!

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

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

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

先写好吧。 您希望在应用程序中导航,从您的应用程序中为另一个链接导航。 这是代码:

 window.location.href = "http://www.google.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的引用。 高尔夫显然不是你应该在代码高尔夫之外做的事情,而且这个答案显然不是高尔夫球。

基本上,畏缩。

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

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

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

     Your Document Title     
You will be redirected in 8 seconds!

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

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

和…

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

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

编辑: window前缀是可选的。

我只需要用另一个更新的jQuery方法来更新这种荒谬:

 var url = 'http://www.fiftywaystoleaveyourlocation.com'; $(location).prop('href', url);