当前位置:  开发笔记 > 编程语言 > 正文

如何重定向到其他网页?

如何解决《如何重定向到其他网页?》经验,为你挑选了58个好方法。

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



1> Ryan McGeary..:

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


问题是关于javascript的具体,但值得注意的是,如果用户禁用了javascript,则可以将元刷新用作故障恢复
在提交按钮的情况下添加return false; 也在你的功能里面
如果你已经在使用jQuery,只需使用`$(location).attr('href',url);`.`window.location.href`似乎在某些浏览器中有不一致的行为,事实上,它在我的Firefox版本中不起作用.我听说过设置`window.location`直接不能在IE版本中工作.
@NicolòMartiniIf(IE)document.write("");
应该删除"更好".正如答案后面所述,最佳解决方案是情境化.OP不会问"如何使用Javascript模拟HTTP重定向..."
如果链接以"www"开头,则不起作用.它只适用于`http`或`https`.但是我们怎样才能确保该网站甚至支持"https"?
我可以使用哪些代码,以便重定向在生产和开发中起作用?因为域名当然不同
此代码存在问题,因为当您使用后退按钮返回时,相同的代码不起作用.它不再起作用了.
尽管我已经在许多项目中使用并且仍然使用jQuery,但是每当我不得不重定向页面时,我总是使用** window.location。***。我认为,当我们使用JavaScript时,应使用内置方法(如果可用且正确实现的话)。

2> Boris Guéry..:

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

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


以这种方式强制jQuery进入等式是荒谬和毫无意义的,特别是因为`window.location`不是一个元素,因此没有属性.
@deltaray这不是****另一种重定向方式,如上所述,它是位置对象周围的无意义包装器,甚至不是元素!这让我想起了http://i.stack.imgur.com/ssRUr.gif
这就是问题的字面答案.如果您已经在使用Jquery并因此已经加载了它,那么它将提高带宽效率,当然使用快捷方式更清晰
更重要的是,有没有办法用jQuery做到这一点,这是旷日持久的?这只是window.location.href = url的包装器; 但是如果jQuery有一些函数,如果window.location.href = url; 是不是在当前的环境(浏览器,操作系统等)工作jQuery核心可以补偿?
我怀疑这仍然适用于最近的jQuery版本,其中`.attr()`实际设置属性(即`.setAttribute()`)
为什么你会这样做呢?JQuery意味着DOM操作库.不是为了这个.这个解决方案是一个糟糕的解 OP要求JQuery,答案应该是告诉OP不需要JQuery而不用于此.适合工作的正确工具.JQuery非常适合DOM,但不应该被迫执行它不应该做的事情.
这是一个非常非常糟糕的答案,我对它收到的票数感到震惊.attr()方法用于在DOM对象上设置属性值.使用它与此方法的意图相反,因此您无法保证此方法将来可用.
还有`$(location)[0] .href = url;`甚至`$,location.href = url;`我更喜欢第二个jQuery解决方案
不需要警告,OP要求JQ答案,所以他/她将收到.
如果您确切知道jQuery的确是什么,那么它实际上只需设置"location.href"即可进行一百万次操作.这不是浏览器交叉兼容,它不节省带宽.但是如果你想要了解发生的事情:1)$()是一个包装,数组和对象以及DOM中的东西(它的含义)的函数,在这种情况下,"location"是一个对象.在经过另外一百万次操作之后,"attr"在该对象上设置了某个键.这些操作都不包括针对此案例的浏览器检查,因为不存在这样的事情.设置对象的属性只是浪费.
jQuery至少会处理与不同JavaScript API的任何跨浏览器兼容性问题.
人们,也许jQuery不需要重定向.也许jQuery不是重定向的正确方法.也许OP并不真正意味着jQuery,只是Javascript.但事实是你使用jQuery重定向,如果出于任何原因,你想要这样做,这就是(_kinda hacky_)这样做的方法.我认为这个答案,**警告包括**是回答这个问题的最佳方式.
我知道这是一个老问题,有一个好奇心:一些XSS过滤器不允许像`



8> Nadeem Yasin..:

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

window.location = window.location.host

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

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


甚至更简单:`window.location ='/'`
Iftah - 这取决于"基础"元标记.

9> Nikhil Agraw..:

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

var currentLocation = window.location;

URL的基本结构

//:/

在此输入图像描述

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

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

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

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

    查询 - 查询字符串如下路径组件,并且提供的信息,该资源可利用为了某种目的(例如,作为用于搜索的参数或作为要处理的数据)的字符串.

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

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

    hash -Set或返回URL的锚点部分.

    host - 设置或返回URL的主机名和端口.

    hostname - 设置或返回URL的主机名.

    href - 设置或返回整个URL.

    pathname - 设置或返回URL的路径名.

    port - 设置或返回服务器用于URL的端口号.

    protocol - 设置或返回URL的协议.

    search - 设置或返回URL的查询部分

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

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

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

Location Object也有这三种方法

    assign() - 加载新文档.

    reload() - 重新加载当前文档.

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

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



10> Alireza..:

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



11> 小智..:

应该只能设置使用window.location.

例:

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

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

如何重定向到其他网页?



12> Patrick W. M..:

在开始之前,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

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


我通过说它不需要来解决他对jQuery的要求.JQuery有很多非常有用的JavaScript快捷方式,但不需要任何重定向快捷方式.JQuery只是JavaScript.而已.调用重定向的常规方法是使用jQuery来处理他的函数.

13> 小智..:
var url = 'asdf.html';
window.location.href = url;



14> 小智..:

这适用于jQuery:

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



15> ScoRpion..:

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

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

如果你只想要jQuery那么你可以这样做:

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



16> Sakthi Karth..:

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



17> Ashish Ratan..:

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

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

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

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



18> iConnor..:

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

您只需要使用JavaScript即可.这是一些将创建动态重定向页面的小代码.


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

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

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

链接到文档

这就是你用JavaScript 创建一个简单的重定向页面的方法

编辑:

还有一点需要注意.我添加window.location.replace了我的代码,因为我认为它适合重定向页面,但是,你必须知道在使用时window.location.replace你被重定向,当你按下浏览器中的后退按钮时它将不会返回到重定向页面,它将会回到它之前的页面,看看这个小小的演示事物.

例:

过程:store home => redirect page to google => google

在google:google => 后退按钮在浏览器 => 存储主页

所以,如果这符合您的需求,那么一切都应该没问题.如果要在浏览器历史记录中包含重定向页面,请将其替换为

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

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



19> SergeDirect..:

*****原始问题是 - "如何重新使用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,您只需一两行即可连接到此代码.



20> Swaprks..:

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

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



21> tilak..:

试试这个:

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

示例的代码段.



22> MayorMonty..:

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

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

就这么简单!

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



23> Anup..:

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

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

如果你想在你的应用程序中导航页面,那么我也有代码,如果你想.



24> Azam Alvi..:

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

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



25> 小智..:

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

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



26> lalithkumar..:

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



27> 1j01..:
ECMAScript 6 + jQuery,85字节
$({jQueryCode:(url)=>location.replace(url)}).attr("jQueryCode")("http://example.com")

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

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

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

其他答案使用jQuery的attr()locationwindow不必要的对象.

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

jQueryCode虽然没有关于它的jQuery,但函数被命名,并且调用函数somethingCode是非常可怕的,特别是当某些东西甚至不是一种语言时.

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

基本上,畏缩.



28> Stefan Gruen..:

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





    
    Your Document Title
    



    
    
You will be redirected in 8 seconds!


最好这样做:setTimeout(function(){window.location.href ="http://www.google.com/"},延迟);

29> Ben..:

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

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

和...

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

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

编辑:window前缀是可选的.



30> Epiphany..:

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

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



31> Bidyut..:

在PHP,HTML或jQuery部分之后编写以下代码.如果在PHP或HTML部分的中间,则使用

56> devst3r..:


使用jQuery/JavaScript重定向用户

通过在jQuery或JavaScript中使用location对象,我们可以将用户重定向到另一个网页.

在jQuery中

将用户从一个页面重定向到另一个页面的代码是:

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

在JavaScript中

将用户从一个页面重定向到另一个页面的代码是:

var url = 'http://www.example.com';
window.location.href = url;

要么

var url = 'http://www.example.com';
window.location = url;



57> dnxit..:

这就是我使用它的方式.

   window.location.replace('yourPage.aspx');   
   // If you're on root and redirection page is also on the root

   window.location.replace(window.location.host + '/subDirectory/yourPage.aspx');

   // If you're in sub directory and redirection page is also in some other sub directory.



58> Omkaar.K..:

以我的工作经验来看,JavaScript重定向要好得多。

这取决于您要如何更改位置。如果要在用户历史记录中记录网站,请使用window.location.href='ur website';。否则,无需登录历史记录即可使用window.location.replace("your website");

推荐阅读
Gbom2402851125
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有