javascript - 重定向redirect - 页面跳转的几种方式




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

如果你对你正在做的事情有更多的描述,这将有所帮助。 如果您正在尝试生成分页数据,那么在执行此操作时有一些选项。 您可以为每个想要直接获取的页面生成单独的链接。

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

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


var url = 'asdf.html';
window.location.href = url;

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

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

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


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

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

所以,问题是如何做一个重定向页面,而不是如何重定向到一个网站?

你只需要使用JavaScript来做到这一点。 以下是一些可以创建动态重定向页面的小代码。

<script>
    var url = window.location.search.split('url=')[1]; // Get the URL after ?url=
    if( url ) window.location.replace(url);
</script>

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

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

如果你去那个链接,它会自动将你重定向到.com

链接到文档

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

编辑:

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

例:

这个过程: store home => 重定向页面到google => google

当在谷歌: 谷歌 => 后退按钮浏览器 => 存储在家中

所以,如果这符合你的需求,那么一切都应该是好的。 如果您想在浏览器历史记录中包含重定向页面,请将其替换

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

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

你可以做到这一点,没有jQuery:

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

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

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

有三种主要的方法来做到这一点,

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

和...

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

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

编辑: window前缀是可选的。


警告:这个答案只是提供了一个可能的解决方案; 这显然不是最好的解决方案,因为它需要jQuery。 相反,更喜欢纯粹的JavaScript解决方案。

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


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

<!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中重定向:

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

只是重定向到一个页面:

  window.location.href = "/destination.html";

或者,如果您需要延迟:

setTimeout(function () {
  window.location.href = "/destination.html";
}, 2000);   // Time in milliseconds

jQuery允许您轻松地从网页中选择元素。 您可以在页面中找到任何您想要的内容,然后使用jQuery添加特殊效果,对用户操作做出反应,或者在所选元素内部或外部显示和隐藏内容。 所有这些任务从知道如何选择一个元素开始

function redirect () {
    $('selection').animate({
        marginLeft: 100px; //Put some CSS animation here
    }, 500, function () {
      // OK, finished jQuery staff, let's go redirect
      window.location.href = "/destination.html";
})

想象一下,有人写了一个脚本/插件是10000行的代码?! 那么,使用jQuery,你可以用一两行连接到这个代码。


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


标准的“香草”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 < 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')

这适用于jQuery:

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

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


一个不会简单地使用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://.com");

// similar behavior as clicking on a link
window.location.href = "http://.com";

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

var currentLocation = window.location;

URL的基本结构

<protocol>//<hostname>:<port>/<pathname><search><hash>

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

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

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

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

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

  6. 散列 - URL的锚点部分包含散列符号(#)。

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

  1. 散列值 - 设置或返回URL的锚点部分。
  2. 主机 - 设置或返回URL的主机名和端口。
  3. hostname - 设置或返回URL的主机名。
  4. href - 设置或返回整个网址。
  5. 路径名 - 设置或返回URL的路径名称。
  6. 端口 - 设置或返回服务器用于URL的端口号。
  7. 协议 - 设置或返回URL的协议。
  8. 搜索 - 设置或返回URL的查询部分

现在,如果您想更改页面或将用户重定向到其他页面,则可以使用Location对象的href属性,如下所示

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

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

位置对象也有这三个方法

  1. assign() - 加载一个新文档。
  2. reload() - 重新加载当前文档。
  3. 替换() - 用新的替换当前文档

您可以使用assign()并替换方法来重定向到其他页面

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

location.replace("http://www..com");

如何分配()和替换()不同 - replace()方法和assign()方法()之间的区别是,replace()从文档历史中删除当前文档的URL,意味着它是不可能使用“返回”按钮导航回到原始文档。 所以,如果你想加载一个新的文档,那么使用assign()方法,并且想要选择导航回到原始文档。

你也可以像这样使用jQuery来更改位置对象的href属性

$(location).attr('href',url);

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







redirect