本文作者:DurkBlue

谈谈Pjax是如何整合进网站从而实现全站无刷新直接加载的推荐

DurkBlue 2019-11-15 2274
谈谈Pjax是如何整合进网站从而实现全站无刷新直接加载的摘要: 曾几何时Pjax很是盛行,但是近几年并没有特别大的动静,可能不想https那么刚需吧,我之前也没有研究过pjax,毕竟对于当时来说算是一门新技术,但是由于需要的人很多,做过一款Pj...

曾几何时Pjax很是盛行,但是近几年并没有特别大的动静,可能不想https那么刚需吧,我之前也没有研究过pjax,毕竟对于当时来说算是一门新技术,但是由于需要的人很多,做过一款Pjax的主题,就是brieflee,但是后期因为与某些插件不兼容也就未在继续更新。要说Pjax就目前ZBP而言,个人认为做的比较出色的就是小峰博客了,我之前的Pjax也是使用他网站的封装的JS代码。因为Pjax对收录不是很友好,大型网站还是不建议使用的,如果有技术大牛在,可以不影响收录又能实现pjax功能还是很牛掰的,最好是小型个人博客尝试体验,最新的微博秀主题刚刚实现这一功能,需要的朋友可以去体会下,今天简单聊聊Pjax是如何整合进网站,实现全站无刷新加载的。

谈谈Pjax是如何整合进网站从而实现全站无刷新直接加载的  第1张

pjax工作原理

pjax 的实现是利用 HTML5 的 pushState() 和 replaceState() 新特性和 ajax 结合实现。pushState() 和 replaceState() 用来操作 State(状态)对象,即可添加和修改历史记录,进而更新 url 和提供前进、后退操作 ajax 实现数据的异步加载进而局部刷新。

准备工作

p了解pjax的工作原理之后,就要开始用它了!但是我们要写一套复杂的js去pushState么?答案是不需要的,已经有人封装好了JqueryPjax插件,我们只需用人家写好的插件即可。由于这款插件依赖于jquery,又依赖jq去操作pushState,所以必须下载1.7版本以上的JQ,当然ZBP已经是1.7以上的版本了,可以忽略这步,至于封装好的Pjax,可以前往百度云下载(封装pjax源自小峰博客):

链接: https://www.hepuhua.cn
提取码: frkb 

下载完js代码,我们需要修改一下:

谈谈Pjax是如何整合进网站从而实现全站无刷新直接加载的  第2张 JavaScript
$(function() {
  $(document).pjax('a[target!=_blank]:not(.gn_nav li.nav_sub a,.gn_nav>li a)', '#WB_pjax', {fragment:'#WB_pjax', timeout:8000, scrollTo: false});
	$(document).on("submit",  function(a) {
		$.pjax.submit(a, "#WB_pjax", {
			fragment: "#WB_pjax",
			timeout: 6000,
      scrollTo: false
		})
	});
	$(document).on('pjax:send', function() {
		$(".pjax_loading").show();
	});
	$(document).on('pjax:complete', function() {
		WB_pjaxafter();
		prism_pjaxafter();
		if ($(".pjax_loading").hide());
	});});

其中:.gn_nav li.nav_sub a,.gn_nav>li a ,代表不需要封装的页面链接,例如微博为主题顶部的登录,点击登录需要在后台实现,所以不能在pjax里面重新封装,那么我们就需要把顶部的a链接排除在外,div框架+a标签即可。

然后我们可以看到的是“#WB_pjax”这个是全站DIV容器,如果没有则需要替换你网站的div容器,比如在body内的一个div,如: 

谈谈Pjax是如何整合进网站从而实现全站无刷新直接加载的  第2张 Markup
<body>
  <div id="WB_pjax">
    网站内容部分... 
  </div></body>

这样就清晰多了是吧。继续,我们会看到“.pjax_loading”这个class,那么这个代码是写在全局底部的,就是启用一个缓冲的作用,在加载新页面的时候,过渡效果,代码如下:

谈谈Pjax是如何整合进网站从而实现全站无刷新直接加载的  第2张 Markup
<div class="pjax_loading"></div><script src='/jquery.pjax.js'></script>

就酱婶的就行了,如果是ZBP的话,放在footer模板文件里,如果用的是我的主题,那么写在“主题设置-广告设置-脚本代码接口(非广告代码)”接口里就行,哦,对了“jquery.pjax.js”目录地址需要自己上传,然后换成自己的目录地址就行了。

顺便把样式给大家,仅供参考:

谈谈Pjax是如何整合进网站从而实现全站无刷新直接加载的  第2张 CSS
/*pjax*/ .pjax_loading{position: fixed;top: 0;left: 0;z-index: 999999;display: none;width: 100%;height: 100%;background-color: #2C3E50;opacity: 0.88;background: url('images/pjax_loading.gif') #fff 50% 50% no-repeat;}

然后看见:

谈谈Pjax是如何整合进网站从而实现全站无刷新直接加载的  第2张 JavaScript
//重载function WB_pjaxafter(){
  $(function() {
    重载JS代码  });}

上面的事情做完了,需要把我们常用的js重新封装加载,具体重载哪些代码因站而议,无法统一,这里不做演示,后续我会把“梦想家”和“锦鲤”主题封装好的js代码放在百度云,需要的自行下载,放在接口就能使用了。

好了,此时大功告成!

此篇文章由DurkBlue发布,撰文不易,转载请注明来处
文章投稿或转载声明

来源:DurkBlue版权归原作者所有,转载请保留出处。本站文章发布于 2019-11-15
温馨提示:文章内容系作者个人观点,不代表DurkBlue博客对其观点赞同或支持。

赞(0)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏

阅读
分享