javascript - js页面跳转 - 如何重定向到其他网页?



15 Answers

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

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

js重定向url

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




使用:

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



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

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



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

window.location = window.location.host

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

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




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

例:

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

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

如何重定向到其他网页?




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

来自Jquery.com的报价:

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

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

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

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

此页面将在3000毫秒后重定向到google.com

<!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 。 如果您确实使用了允许用户返回重定向页面的选项,请记住,当您进入重定向页面时,它会重定向您。 因此,在为重定向选择选项时要考虑到这一点。 在页面仅在用户完成操作时重定向的情况下,然后在后退按钮历史中具有页面将是可以的。 但是,如果页面自动重定向,那么您应该使用替换,以便用户可以使用后退按钮而不会强制返回到重定向发送的页面。

您还可以使用元数据来运行页面重定向,如下所示。

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=en&ref_topic=6001971https://support.google.com/webmasters/answer/2721217?hl=en&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>

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




你可以在没有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://.com");

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

window.location.replace("http://.com");
window.location.href("http://.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,您只需一两行即可连接到此代码。




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

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

就这么简单!

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




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

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

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




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

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



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

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



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

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



Related