如何使用jQuery或纯JavaScript将用户从一个页面重定向到另一个页面?
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')
但如果有人想重定向回主页,那么他可能会使用以下代码段.
window.location = window.location.host
如果您有三个不同的环境,如开发,登台和生产,将会很有帮助.
只需将这些单词放在Chrome控制台或Firebug的控制台中,即可浏览此窗口或window.location对象.
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);
因此,您可以将用户重定向到其他网址.
基本上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");
我还会在下面的图片中显示所有内容:
应该只能设置使用window.location
.
例:
window.location = "https://stackoverflow.com/";
这是关于这个主题的过去的帖子:
如何重定向到其他网页?
在开始之前,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.href
或window.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).attr("location", "http://google.fr");
你可以在没有jQuery的情况下做到这一点:
window.location = "http://yourdomain.com";
如果你只想要jQuery那么你可以这样做:
$jq(window).attr("location","http://yourdomain.com");
#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";
.
您需要在代码中添加以下行:
$(location).attr("href","http://stackoverflow.com");
如果您没有jQuery,请使用以下命令运行JavaScript:
window.location.replace("http://stackoverflow.com"); window.location.href("http://stackoverflow.com");
那么,问题是如何制作重定向页面,而不是如何重定向到网站?
您只需要使用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;
*****原始问题是 - "如何重新使用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,您只需一两行即可连接到此代码.
在您的点击功能上,只需添加:
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.你可以这样做:
window.open("URL","_self","","")
就这么简单!
启动HTTP请求的最佳方法是使用document.loacation.href.replace('URL')
.
先写好.您希望在应用程序中导航,从您的应用程序中为另一个链接导航.这是代码:
window.location.href = "http://www.google.com";
如果你想在你的应用程序中导航页面,那么我也有代码,如果你想.
您可以像这样在jQuery中重定向:
$(location).attr('href', 'http://yourPage.com/');
在JavaScript和jQuery中,我们可以使用以下代码将一个页面重定向到另一个页面:
window.location.href="http://google.com"; window.location.replace("page1.html");
使用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
$({jQueryCode:(url)=>location.replace(url)}).attr("jQueryCode")("http://example.com")
请不要杀我,这是个玩笑.这是个玩笑.这是个玩笑.
这确实"提供了问题的答案",因为它要求"使用jQuery"的解决方案,在这种情况下需要以某种方式强制它进入等式.
Ferrybig显然需要解释这个笑话(仍在开玩笑,我确信评论表上的选项有限),所以不用多说:
其他答案使用jQuery的attr()
的location
或window
不必要的对象.
这个答案也滥用它,但是更加荒谬.它不是用它来设置位置,而是attr()
用来检索设置位置的函数.
jQueryCode
虽然没有关于它的jQuery,但函数被命名,并且调用函数somethingCode
是非常可怕的,特别是当某些东西甚至不是一种语言时.
"85字节"是对Code Golf的引用.高尔夫显然不是你应该在代码高尔夫之外做的事情,而且这个答案显然不是高尔夫球.
基本上,畏缩.
这是一个延时重定向.您可以将延迟时间设置为您想要的任何值:
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);
在PHP,HTML或jQuery部分之后编写以下代码.如果在PHP或HTML部分的中间,则使用