如何使用jquery.pjax实现SPA单页面应用

发布时间:2021-08-10 09:45:03 作者:chen
来源:亿速云 阅读:134

本篇内容主要讲解“如何使用jquery.pjax实现SPA单页面应用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用jquery.pjax实现SPA单页面应用”吧!

今天我要给大家分享的这个实例是模拟分页功能,分页是在web开发中最常见的组件之一。正常情况下,点击分页组件中的页面,页面会跳转到对应的页面,而使用Pjax后,点击页码时,会发送一个ajax请求到后端,响应后更新对应的页面内容部分,同时地址栏url也对应实际的页码url,但整个页面并没有跳转,给我们的感觉是非常流畅,当然,我们也可以在请求页面异步时增加加载动画效果。来看具体的使用方法。

HTML

我们准备一个加载p#loading,默认隐藏,ajax请求的时候才显示。#container是用来加载响应的页面内容。.pagination是分页条组件。

<p class="row">    <p id="loading">Loading...</p>    <p id="container">jQuery.pjax分页</p>    <nav>      <ul class="pagination">        <li><a href="data.php?p=1">1</a></li>        <li><a href="data.php?p=2">2</a></li>        <li><a href="data.php?p=3">3</a></li>        <li><a href="data.php?p=4">4</a></li>        <li><a href="data.php?p=5">5</a></li>      </ul>    </nav> </p>

Javascript

我们使用的pjax组件依赖jQuery库,所以先将这两个文件加载。

<script src="jquery-2.0.0.min.js"></script> <script src="jquery.pjax.js"></script>

然后,使用以下代码调用pjax插件。

$(document).pjax('.pagination a', '#container'); $(document).on('pjax:send', function() {  $('#loading').show(); }) $(document).on('pjax:complete', function() {  $('#loading').hide(); })

上面的代码中,我们告诉pjax监听一个标签和使用 #container 作为目标容器:

$(document).pjax('.pagination a', '#container');

现在在pjax兼容浏览器,点击分页条上的页码,网页的内容容器 #container 中的内容将被 data.php?p=x 的内容替换。

data.php的内容我们简单的写个代码,实际开发中应该是读取数据库中的数据列表。

$p = intval($_GET['p']); if($p==0) $p=1; echo '这是第'.$p.'页';

选项与事件

pjax的调用方法我们刚才简单介绍了,它还可以设置一些选项用来定制。格式如下:

$(document).pjax(selector, [container], options)

selector 是一个字符串,比如要点击的文本 event delegation.

container 是一个字符串,选择唯一标识pjax容器。

options 下面所描述的一个对象。

参数描述默认值timeoutAjax超时毫秒之后完全强制刷新650push使用 pushState 在导航中添加浏览器历史记录truereplace更换网址不添加浏览器历史记录falsemaxCacheLength大缓存大小为以前的容器内容20version一个字符串或函数返回当前pjax版 scrollTo垂直位置以滚动导航。为了避免改变滚动位置,通过设置为 false.0type网页请求的方式"GET"dataType返回的数据类型"html"containerCSS选择器的元素,其中的内容应及时更换 url字符串或函数返回的URL ajax请求link.hreftarget最终 relatedTarget 的值,通过 pjax eventslinkfragmentCSS选择器的碎片从Ajax响应提取 

事件方法

事件描述pjax:click阻止一个链接的默认事件,防止阻止pjax事件pjax:beforeSend参见 XHR headerspjax:start请求开始pjax:send发送请求pjax:clickedpjax后,已经得到了从点击一个链接开始pjax:beforeReplace在内容被替换前,HTML从服务器加载的内容pjax:success在内容被替换后,HTML 内容从服务器加载pjax:timeout在选项 options.timeout;之后除非取消,否则将很难刷新pjax:error一个ajax错误,将执行原始的网页刷新,直到网页加载被取消pjax:complete总是在pjax执行完成以后调用,不论运行的结果pjax:end请求结束pjax:popstate浏览器前进后退事件 direction 属性:”back”/”forward”

$.pjax还能响应点击事件,以及提交表单和重新加载事件。详情请参考jquery.pjax项目地址:https://github.com/defunkt/jquery-pjax

到此,相信大家对“如何使用jquery.pjax实现SPA单页面应用”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

推荐阅读:
  1. vue中怎么利用SPA实现一个单页面应用
  2. vue路由嵌套的SPA实现步骤

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

jquery pjax

上一篇:怎么测试JavaScript框架库jQuery

下一篇:前端jQuery弹框阻止冒泡代码分享

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》