想要更详细了解pjax,需要查看官网

或者看本站文章:jQuery.pjax.js:使用AJAX和pushState无刷新加载网页(官网教程中文翻译)

效果看本站,音乐无刷新播放,代码高亮和复制js加载成功~

准备文件

编辑模板 header.php 的 head 添加必要文件:

jquery-1.11.1.min.js百度网盘下载

jquery.pjax-1.8.2.min.js百度网盘下载

下载到模板的 scripts 目录下后将下面两句添加到</head>所有script标签的最前面:

点击预览

<script type="text/javascript" src="<?php echo TEMPLATE_URL; ?>scripts/jquery-1.11.1.min.js"></script>
<script type="text/javascript" src="<?php echo TEMPLATE_URL; ?>scripts/jquery.pjax-1.8.2.min.js"></script>

注意:jQuery需要1.7.0版本以上的才有pushState的封装

使用pjax

编辑模版 footer.php 在/body标记结束前插入:

< script  type="text/javascript">
 $(document).pjax('a[target!=_blank]', '#contentleft', {fragment: '#contentleft',timeout: 8000}); 
 < /script>

参数解释:

  1. a[target!=_blank]:绑定本页面非新窗口打开的所有链接

  2. #contentleft:链接点击之后,仅仅更新#contentleft容器的内容,页面其他内容不变,需自行修改这个参数

  3. fragment:'#contentleft':#contentleft选择器的碎片从Ajax响应提取

  4. timeout:8000:Ajax超时时间为8秒,如果未响应则直接刷新网页

注意:这个 #contentleft 怎么找呢?

小指的方法是打开模板的 echo_log.php,找到包裹文章页面的 div 的 id 就是了,一般是第一第二个

id 名字都是 contentleft,content或者main之类的,按照这个方法一般都可以了,如果不行回我吧~

解决pjax的缓冲--加入等待动画

编辑模板 footer.php 在/body标记前插入下面代码

点击预览

<div class="qingzz_pjax_loading">
    <div class="qingzz_pjax_spinner">
        <div class="qingzz_pjax_rect1"></div>
<div class="qingzz_pjax_rect2"></div>
<div class="qingzz_pjax_rect3"></div>
<div class="qingzz_pjax_rect4"></div>
<div class="qingzz_pjax_rect5"></div>
    </div>
</div>
<script>
$(document).on('pjax:send', function() { //pjax链接点击后显示加载动画;
    $(".qingzz_pjax_loading").css("display", "block");
});
$(document).on('pjax:complete', function() { //pjax链接加载完成后隐藏加载动画;
    $(".qingzz_pjax_loading").css("display", "none");
});
</script>

没有用音乐插件的需要在模板css文件末尾添加css:

.qingzz_pjax_loading {
height: 100%;
width: 100%;
position: fixed;
top: 0;
left: 0;
z-index: 1000;
background-color: rgba(90,90,90,.5);
display: none;
}
.qingzz_pjax_spinner {
  margin: 300px auto;
  width: 50px;
  height: 60px;
  text-align: center;
  font-size: 10px;
}
.qingzz_pjax_spinner > div {
  background-color: #67CF22;
  height: 100%;
  width: 6px;
  display: inline-block;
  -webkit-animation: stretchdelay 1.2s infinite ease-in-out;
  animation: stretchdelay 1.2s infinite ease-in-out;
}
.qingzz_pjax_spinner .qingzz_pjax_rect2 {
  -webkit-animation-delay: -1.1s;
  animation-delay: -1.1s;
}
.qingzz_pjax_spinner .qingzz_pjax_rect3 {
  -webkit-animation-delay: -1.0s;
  animation-delay: -1.0s;
} .qingzz_pjax_spinner .qingzz_pjax_rect4 {
  -webkit-animation-delay: -0.9s;
  animation-delay: -0.9s;
}
.qingzz_pjax_spinner .qingzz_pjax_rect5 {
  -webkit-animation-delay: -0.8s;
  animation-delay: -0.8s;
}
@-webkit-keyframes stretchdelay {
  0%, 40%, 100% { -webkit-transform: scaleY(0.4) }
  20% { -webkit-transform: scaleY(1.0) }
}
@keyframes stretchdelay {
  0%, 40%, 100% {
    transform: scaleY(0.4);
    -webkit-transform: scaleY(0.4);
  }  20% {
    transform: scaleY(1.0);
    -webkit-transform: scaleY(1.0);
  }
}

刷新一下,挺酷的吧~

解决无法提交和多说不加载问题:

编辑模板的 footer.php,在/body标签前添加下面这段代码:

点击预览

<script>
$(document).on('submit', 'form', function(event) {// 解决提交失效问题
    $.pjax.submit(event, '#contentleft', {fragment: '#contentleft',timeout: 8000});
 });
$(document).on('pjax:complete', function() {
    pajx_loadDuodsuo();//pjax加载完成之后调用重载多说函数
});
function pajx_loadDuodsuo(){
    var dus=$(".ds-thread");
    if($(dus).length==1){
        var el = document.createElement('div');
        el.setAttribute('data-thread-key',$(dus).attr("data-thread-key"));//必选参数
        el.setAttribute('data-url',$(dus).attr("data-url"));
        DUOSHUO.EmbedThread(el);
        $(dus).html(el);
    }
}
</script>

里面的#contentleft一样需要改成前面的容器id哦~

总结footer.php需要添加的代码:

点击预览

<div class="qingzz_pjax_loading">
    <div class="qingzz_pjax_spinner">
        <div class="qingzz_pjax_rect1"></div>
<div class="qingzz_pjax_rect2"></div>
<div class="qingzz_pjax_rect3"></div>
<div class="qingzz_pjax_rect4"></div>
<div class="qingzz_pjax_rect5"></div>
    </div>
</div>
<script>
// 绑定链接和容器
$(document).pjax('a[target!=_blank]', '#contentleft', {fragment: '#contentleft',timeout: 8000}); 
$(document).on('submit', 'form', function(event) {// 解决提交失效问题
    $.pjax.submit(event, '#contentleft', {fragment: '#contentleft',timeout: 8000});
 });
$(document).on('pjax:send', function() { //pjax链接点击后显示加载动画;
    $(".qingzz_pjax_loading").css("display", "block");
});
$(document).on('pjax:complete', function() { //pjax链接加载完成后隐藏加载动画;
    $(".qingzz_pjax_loading").css("display", "none");
    pajx_loadDuodsuo();//pjax加载完成之后调用重载多说函数
});
function pajx_loadDuodsuo(){
    var dus=$(".ds-thread");
    if($(dus).length==1){
        var el = document.createElement('div');
        el.setAttribute('data-thread-key',$(dus).attr("data-thread-key"));//必选参数
        el.setAttribute('data-url',$(dus).attr("data-url"));
        DUOSHUO.EmbedThread(el);
        $(dus).html(el);
    }
}
</script>

解决容器中javascript事件失效的问题:重点

问题:pjax之后多说评论框不加载,ajax评论不能提交等等问题。

问题原因:原先容器绑定的事件被新容器替换掉了,新容器的div没有绑定事件,所以点击无效。

解决方法一:利用pjax的加载完成回调函数,重新绑定事件。

解决方法二:将javascript添加到 echo_log.php 的容器,一般加到容器末尾,即/div标签上面。

更准确的方法查看本站文章:

pjax javascript失效解决(小指亲测)

将javascript添加到 echo_log.php 的容器

原理是容器里面的内容是会刷新重新加载的,所以把javascript放在这里会重新加载~

这里只列出常用的,其他具体的自行摸索添加吧~

最好放到容器末尾/div前面哦~

解决代码高亮问题添加:

<script src="<?php echo BLOG_URL; ?>admin/editor/plugins/code/prettify.js" data-no-instant></script>
<script>prettyPrint();</script>

解决CNZZ统计问题,前面是解释具体方法在最后:

pjax CNZZ统计失效解决(小指亲测)

解决百度统计问题:

pjax 百度统计失效解决(小指亲测)

好啦,完美解决了吧,哈哈哈^_^

emlog通过pjax实现无刷新加载网页--完美解决cnzz统计和javascript失效问题的更多相关文章

  1. jQuery Pjax – 页面无刷新加载,优化用户体验

    pjax 是 HTML5 pushState 以及 Ajax 两项技术的简称,综合这两个技术可以实现在不刷新页面的情况下载入 HTML 到当前网页,带给你超快速的浏览器体验,而且有固定链接.标题以及后 ...

  2. js中对arry数组的各种操作小结 瀑布流AJAX无刷新加载数据列表--当页面滚动到Id时再继续加载数据 web前端url传递值 js加密解密 HTML中让表单input等文本框为只读不可编辑的方法 js监听用户的键盘敲击事件,兼容各大主流浏览器 HTML特殊字符

    js中对arry数组的各种操作小结   最近工作比较轻松,于是就花时间从头到尾的对js进行了详细的学习和复习,在看书的过程中,发现自己平时在做项目的过程中有很多地方想得不过全面,写的不够合理,所以说啊 ...

  3. 瀑布流AJAX无刷新加载数据列表--当页面滚动到Id时再继续加载数据

    瀑布流加载显示数据,在当下已经用的很普遍,尤其是我们在做网上商城时,在产品列表页面已经被普遍使用. 对于实现瀑布流布局的解决方案主要有以下两种方式: 1.对每一条显示数据使用绝对定位+浮动的方式,这样 ...

  4. jquery完成界面无刷新加载登陆注册

    昨天公司说官网的登陆注册每次要跳转到另一个界面,能不能做一个简单的,在界面弹出一个框框登陆,我想了想做了这么一个案例,大家来看看成不成 贴上代码,实现了在同一个弹出窗上加载了登陆注册功能!可自由点击! ...

  5. asp.net mvc 无刷新加载

    1.视图(index) <!--start--> <div data-am-widget="list_news" class="am-list-news ...

  6. ajax实现下拉菜单无刷新加载更多

    $(function() { var page = 1; var discount = $('#discount'); var innerHeight = window.innerHeight; va ...

  7. pushState与ajax实现无刷新加载

    一.JS代码: $(document).ready(function() { getContent();//初始化页面 $("nav a").click(function() { ...

  8. jquery+ajax无刷新加载数据,新闻浏览更多

      <script type="text/javascript"> $(document).ready(function (){ $(window).scroll(fu ...

  9. thinkphp5.0调用ajax无刷新加载数据

    控制器层那边就是调数据返回,这里不再赘述,视图层页面ajax部分写法如下 function shanchu(obj) { var code = $(obj).attr("code" ...

随机推荐

  1. 敏捷开发系列学习总结(4)—Git管理工具sourcetree的安装

    现在代码管理都流行用git了,小编以前用过clearcase, svn,vss等.现在用了git后,发现git才是最好的,我觉得它最吸引人的地方应该是它的分布式管理吧.git的具体学习,读者可自己去网 ...

  2. 洛谷——P2722 总分 Score Inflation

    https://www.luogu.org/problem/show?pid=2722 题目背景 学生在我们USACO的竞赛中的得分越多我们越高兴. 我们试着设计我们的竞赛以便人们能尽可能的多得分,这 ...

  3. HDU 4519

    实现简单,但不得不说是一道好题. 当员工数少于医生数时,直接输出K,因为此时N个员工同时检查,必定是最少的时间了. 当员工数大于医生数时,可以把员工的项目看成一段一段的,每个医生对其进行切割,总能得到 ...

  4. LeetCode 122 Best Time to Buy and Sell Stock II(股票买入卖出的最佳时间 II)

    翻译 话说你有一个数组,当中第i个元素表示第i天的股票价格. 设计一个算法以找到最大利润. 你能够尽可能多的进行交易(比如.多次买入卖出股票). 然而,你不能在同一时间来多次交易. (比如.你必须在下 ...

  5. Uva 1331 - Minimax Triangulation(最优三角剖分 区间DP)

    题目大意:依照顺时针或者逆时针的顺序给出多边的点,要将这个多边形分解成n-2个三角形,要求使得这些三角行中面积最大的三角形面积尽量小,求最小值. 思路:用区间DP能够非常方便解决,多边形可能是凹边形, ...

  6. OC基础回想(十二)协议

    在OC基础(十一)中我们讨论了类别和非正式协议的奇异之处.在使用非正式协议时.能够仅仅实现你想要获得响应的方法.也不必在对象中声明不论什么内容来表示该对象可用作托付对象. 全部这些任务能够用最少的代码 ...

  7. vsftpd出现“Response: 500 OOPS: cannot change directory”解决方法(转载)

    vsftpd出现“Response: 500 OOPS: cannot change directory”解决方法   笔者用的Linux发行版本为centos当用FTP客户端连接时,出现如下错误提示 ...

  8. list.subList

    import java.util.ArrayList;import java.util.List; public class Test2 {    public static void main(St ...

  9. Privoxy shadowscocks代理

    ubuntu已经启动好了sock5的代理, 代理为: 127.0.0.1:1080. #使用Privoxy将sock5代理映射为http代理. 安装Privoxy sudo apt-get updat ...

  10. 假脱机服务(SPOOLing service)

    1. 基本含义 SPOOLing 是 Simultaneous Peripheral(外设) Operation On-Line(联机) 的缩写,是关于慢速字符设备(慢速外设,比如打印机)如何与计算机 ...