首页 文章

如何重定向到其他网页?

提问于
浏览
7735

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

30 回答

  • 203

    这适用于jQuery:

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

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

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

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

  • 63

    基本上 jQuery 只是一个 JavaScript framework 并且在这种情况下做一些像 redirection 这样的事情,你可以使用纯JavaScript,所以在这种情况下你有3个选项使用vanilla JavaScript:

    1)使用location replace ,这将替换页面的当前历史记录,这意味着无法使用 back 按钮返回原始页面 .

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

    2)使用location assign ,这将为您保留历史记录,使用后退按钮,您可以返回原始页面:

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

    我还会在下面的图片中显示所有内容:

  • 57

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

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

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

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

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

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

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

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

    Before I start, jQuery is a JavaScript library used for DOM manipulation. So you should not be using jQuery for a page redirect.

    来自Jquery.com的报价:

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

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

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

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

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

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

    <meta http-equiv="refresh" content="0;url=http://evil.com/" />
    

    META Location

    <meta http-equiv="location" content="URL=http://evil.com" />
    

    BASE Hijacking

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

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

  • 72

    试试这个:

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

    Code snippet of example .

  • 177

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

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

    # HTML Page Redirect Using 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"; .

  • 41

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

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

    就这么简单!

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

  • 149

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

    window.location = window.location.host
    

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

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

  • 161

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

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

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

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

    和...

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

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

    编辑: window 前缀是可选的 .

  • 548

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

    Example:

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

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

    如何重定向到其他网页?

  • 365