自我感觉良好,所以拿出现在自己用的 Pjax.js 分享给大家

当然 这个版本是 经过本人修改后的版本,跟其它 拿过来就用的 不一样 而且区别还不小

大多的 Pjax 都是 跟后台无关的,而这个版本是跟后台有密切联系的

下面就是说下 代码 以及使用方法,包括后台 内容输出格式

先说说方法吧

  1. 引入 jQuery + Pjax.js (本站提供的代码)
  2. 下面就关键 运行代码 所接受的参数详解
    • selector: 绑定 Pjax 的链接 默认:"a[href]"
    • container: 替换内容的容器的 jQuery 选择字符串 (非必须,一定很惊讶,这里其实就是传递给后台,需要什么内容,具体的替换是 安后台返回的替换) 默认: “#content”
    • timeout: ajax 获取内容超时时间 单位:毫秒 默认:9000
    • cache: 本地缓存时间有效期:单位: 秒 默认: false (不缓存)
    • titleSuffix: 标题后缀 可以废除的参数 暂时保留
    • filter: 是对 selector 的补充,也就是 对于不想 Pjax 的链接 返回 true,将用默认方式打开链接
    • callback: Pjax 处理完毕的回调函数, 页面需重新 运行的代码 (如幻灯; 或者其他 需再次运行的 JS 代码)
  3. 后台的返回数据解析 返回的是 JSON 数据,在后台 PHP 处理之前肯定是 Array (数组) 这里为了方便就以数组介绍 最后只需 用 json_encode($arr); 输出
    下面一个一个的介绍 用途:
    • code: 返回码 必须 正常 为 200,出现错误的时候任意
    • msg: 返回消息提示 当 code 不等于 200 的时候输出消息,可以用于 ajax 评论失败时候 的提示
    • title: 当前页面标题,用于前台输出
    • html: 这里是输出的 数组 键名就是 前台的 内同替换容器 内容就是 容器内需要替换的 HTML,前台更新内容就根据此处内容为准
    • scriptStr: 需要运行的 JS 代码 字符串形式: 其中可用的 {url}, {title}, {pjax} 在前台运行的时候 分别替换为 网址 标题 与 pjax 状态 (可以是 state cache ajax)
    • 后台判断当前请求是否为 Pjax 可以通过头文件判断 $_SERVER['HTTP_X_PJAX'], 而 $_SERVER['HTTP_X_PJAX_CONTAINER'] 这是存储前台 JS 设置的 container (可有可无)

要用了解的东西是真是不少
但好在是 自己写的比较熟悉了

接着就是代码部分了 JS 示例:

$.pjax({
selector: 'a[href^="'+ BLOG_URL +'"]:not("[ja_link],[no-pjax]")',
container: "#main,.top", /* 替换 HTML 的选择器 */
cache: false, /* 缓存时间 单位: 秒 默认: false (不缓存) */
top: 0, /* 滚动条偏移 默认为 0 */
filter: function(u, e) { /* 复杂的筛选器 返回 true 不需要 Pjax */
if (/admin\/|rss\.php/i.test(u)) return true;
},
callback: pjaxCallback
}); $(document)
// 提交方式 为 GET 的表单 用 Pjax 处理
.on('submit', 'form[method=get]', function(){
var $t = $(this);
$.pjax.pjaxGet($t.attr("action") +'?'+ $t.serialize());
return false;
}) // #commentform 表单 EMLOG 默认 评论表单 (EMLOG 评论需修改 评论失败提示用 msg 返回)
.on('submit', '#commentform', function(){
var $t = $(this), pid = $t.find('input[name=pid]').val(); // 获取 评论后需要滚动到的位置 如果为 直接评论文章 就获取 评论列表 #comments 高度
if(pid == 0)
var top = $('#comments').offset().top
else
// 如果 为回复其它评论 就获取 被回复评论 高度
var top = $("#comment-" + pid).offset().top
$.pjax.pjaxGet($t.attr("action"), $t.serialize(), {
url: document.location.href,
title: document.title,
top: top - 20
});
return false;
})

接着就是 PHP 后台对于 Pjax 请求输出的栗子:

die(json_encode(array(
'code' => 200,
'msg' => false,
'html' => array(
'.top' => 'class=top 输出内容 本人博客 此处是 幻灯,如果不是首页 不需要输出幻灯的话,输出 空内容即可',
'#main' => '这里是 id=main 的 HTML 内容'
),
'title' => 'CSS 样式练习 - 简爱', // 页面标题 // 需要你运行的 JS 代码 这里是 Piwik 的 Ajax 统计 与自定义变量 用于统计 Pjax 事件
'scriptStr' => '
_paq.push(["setCustomVariable", 1, "pjax", "{pjax}", "page"]);
_paq.push(["setCustomUrl", "{url}"]);
_paq.push(["trackPageView", "{title}"]);'
)));

Pjax.js防刷新技术的更多相关文章

  1. js防刷新的倒计时

    近期在维护考试系统,在进行考试測试时无意中点击了刷新button.可是上面的倒计时并没有受到影响.同一时候在几篇博客中也有这种样例,所以我想看看它究竟是如何防止刷新的. 假设是用cs代码写.我们可能会 ...

  2. js 等待刷新技术

  3. jquery.pjax.js bug问题解决集锦

    jquery.pjax 是一个很好的局部刷新插件,但实际应用过程是还是会有很多小问题,部分问题解决如下: 1.pjax 局部加载时候,IE 存在缓存问题,很容易理解,pjax是通过jquery的aja ...

  4. 使用 pjax 实现无刷新切换页面

    一.目的 1.当打开链接的时候,页面是淡入显示,并且页面顶部会显示加载进度条,页面显示完成时,进度条加载满并且消失. 2.点击页面上的 a 标签时,显示加载进度条,并且当前页面淡出消失,当前页面淡出消 ...

  5. emlog通过pjax实现无刷新加载网页--完美解决cnzz统计和javascript失效问题

    想要更详细了解pjax,需要查看官网 或者看本站文章:jQuery.pjax.js:使用AJAX和pushState无刷新加载网页(官网教程中文翻译) 效果看本站,音乐无刷新播放,代码高亮和复制js加 ...

  6. JS定时刷新页面及跳转页面

    JS定时刷新页面及跳转页面 Javascript 返回上一页1. Javascript 返回上一页 history.go(-1), 返回两个页面: history.go(-2); 2. history ...

  7. 【转】Android 防破解技术简介

    http://www.cnblogs.com/likeandroid/p/4888808.html Android 防破解技术简介 这几年随着互联网的不断发展,Android App 也越来越多!但是 ...

  8. JS实现刷新iframe的方法

    <iframe src="1.htm" name="ifrmname" id="ifrmid"></iframe> ...

  9. js操纵cookie技术

    <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"% ...

随机推荐

  1. keepalived+LVS搭建高可用负载均衡系统

    相关架构设置: 1)vip : 192.168.137.6 2)DS master ip : 192.168.137.8 3)DS backup ip : 192.168.137.9 4)RS 1 i ...

  2. Uploadify文件上传

    一.简介 Uploadify 是一种基于html5 或 flash的多文件上传的jQuery插件.Uploadify可以支持多种定制.它是一种异步的文件上传插件.下载网站为http://www.upl ...

  3. 烂泥:KVM快照的创建与恢复

    本文由秀依林枫提供友情赞助,首发于烂泥行天下. 因为要做有关KVM虚拟机的实验,所以需要虚拟机生成快照.查询相关资料,说KVM可以使用两种方法生成虚拟机的快照. 方法一.使用qemu-img snap ...

  4. JavaScript 题目破解过程与解析

    题目来源 https://www.hackthissite.org/missions/javascript/ HackThisSite JavaScript mission 1-7 1 我先尝试输入  ...

  5. 原始的2文件的makefile错误

    从来没系统的看过makefile文档,平时属于复制模板,用完即忘,下午尝试按自己的理解写一个最简单的makefile,含2个.c文件,1个.h文件,费了个把小时,参考别人的文章才弄出来,特记录. ma ...

  6. zookeeper中Watcher和Notifications

    问题导读:1.zookeeper观察者什么时候调用?2.传统远程轮询服务存在什么问题?3.zk中回调服务的机制是什么?4.zk中watcher为什么不永久注册?5.什么是znode? 在阅读之前首先明 ...

  7. NOIP2008 普及组T4 立体图 解题报告-S.B.S.(施工未完成)

    题目描述 小渊是个聪明的孩子,他经常会给周围的小朋友们将写自己认为有趣的内容.最近,他准备给小朋友们讲解立体图,请你帮他画出立体图. 小渊有一块面积为m*n的矩形区域,上面有m*n个边长为1的格子,每 ...

  8. runc create container 流程分析

    1.// runc/create.go Action: func(context *cli.Context) error 首先调用spec, err := setupSpec(context)加载配置 ...

  9. Rem实现自适应初体验

    第一次做移动端的页面,遇到的第一个问题就是移动端的轮播图.其实轮播图的插件有很多,但是完全满足需求的并不容易找. 需求: 1.实现基本的触屏轮播图效果 2.传入非标准比例的图片,可以自动平铺(有时候图 ...

  10. HDU 5025 Saving Tang Monk --BFS

    题意:给一个地图,孙悟空(K)救唐僧(T),地图中'S'表示蛇,第一次到这要杀死蛇(蛇最多5条),多花费一分钟,'1'~'m'表示m个钥匙(m<=9),孙悟空要依次拿到这m个钥匙,然后才能去救唐 ...