如何重定向到另一个网页?

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

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

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

如果因为在重定向时丢失 HTTP_REFERER 而来到这里,请继续阅读:

以下部分是针对那些HTTP_REFERER作为许多安全措施之一(尽管这不是一个很好的保护措施)。如果您使用的是Internet Explorer 8或更低版本,则在使用任何形式的JavaScript页面重定向(location.href等)时,这些变量会丢失。

下面我们将实现一个替代IE8&更低,这样我们不会失去HTTP_REFERER。否则,你几乎总是可以简单地使用window.location.href

针对HTTP_REFERER(URL粘贴,会话等)的测试可以有助于判断请求是否合法。 注意:也有办法绕过/欺骗这些推荐人,正如评论中的下垂链接所指出的那样)

简单的跨浏览器测试解决方案(适用于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 <span data-mce-type="bookmark" style="display: inline-block; width: 0px; overflow: hidden; line-height: 0;" class="mce_SELRES_start"></span><span data-mce-type="bookmark" style="display: inline-block; width: 0px; overflow: hidden; line-height: 0;" class="mce_SELRES_start"></span><span data-mce-type="bookmark" style="display: inline-block; width: 0px; overflow: hidden; line-height: 0;" class="mce_SELRES_start"></span>< 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';

如果你对你正在做的事情有更多的描述,这将有所帮助。如果您正在尝试生成分页数据,则可以通过一些选项来实现。您可以为每个想要直接获取的页面生成单独的链接。

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

我也认为这location.replace(URL)是最好的方法,但如果你想通知搜索引擎你的重定向(他们不分析JavaScript代码来看重定向),你应该添加rel="canonical"元标记到您的网站。

添加一个带有HTML刷新元标记的无脚本部分也是一个很好的解决方案。我建议你使用这个JavaScript重定向工具来创建重定向。它还具有Internet Explorer支持来传递HTTP引用。

示例代码没有延迟看起来像这样:

<!-- Place this snippet right after opening the head tag to make it work properly -->

<!-- This code is licensed under GNU GPL v3 -->
<!-- You are allowed to freely copy, distribute and use this code, but removing author credit is strictly prohibited -->
<!-- Generated by http://insider.zone/tools/client-side-url-redirect-generator/ -->

<!-- REDIRECTING STARTS -->
<link rel="canonical" href="https://yourdomain.com/"/>
<noscript>
    <meta http-equiv="refresh" content="0;URL=https://yourdomain.com/">
</noscript>
<!--[if lt IE 9]><script type="text/javascript">var IE_fix=true;</script><![endif]-->
<script type="text/javascript">
    var url = "https://yourdomain.com/";
    if(typeof IE_fix != "undefined") // IE8 and lower fix to pass the http referer
    {
        document.write("redirecting..."); // Don't remove this line or appendChild() will fail because it is called before document.onload to make the redirect as fast as possible. Nobody will see this text, it is only a tech fix.
        var referLink = document.createElement("a");
        referLink.href = url;
        document.body.appendChild(referLink);
        referLink.click();
    }
    else { window.location.replace(url); } // All other browsers
</script>
<!-- Credit goes to http://insider.zone/ -->
<!-- REDIRECTING ENDS -->

添加评论

友情链接:蝴蝶教程