问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

如何将Pjax整合进网站,实现全站无刷新加载

发布网友 发布时间:2022-05-05 00:52

我来回答

2个回答

懂视网 时间:2022-05-15 05:23

本篇文章给大家介绍Yii整合pjax(pushstate+ajax)实现无刷新加载页面,一起学习吧

Pjax是啥?

BOM对象history被增强了一波,主要是对历史栈的操作,以前只有 replace , go 之类的,都会跳转并刷新整个页面,现在有了 pushState , replaceState 等等单纯操作历史栈的方法,只是单纯修改历史栈里的内容,没有副作用(页面不会跳转刷新)

PJAX效果

通过url可以跟踪ajax的动态加载内容。这种技术尤其在two step view布局的视图中有很大的好处。无刷新加载页面,意味着响应速度和用户体验得到了极大的提升,在静态脚本和通用模块比较多的情况下,最大程度上节省了重用部分的开销。应用例子可以参考现在的google+、facebook和新版微博,同样是基于html5的pushState实现。google plus的表现最为明显,点击导航栏地址,箭头随目标移动,同时加载的页面淡入,效果很炫。

Dirty url 和 Clean url

在pjax出现之前,要实现页面的无刷新加载并通过url可以追踪,需要浏览器支持window.location.hash属性。通过判断url#锚后记录的地址来决定需要加载的内容,具体的构建方法是写一个hashchange的监视函数,当触发到hash改变时便判断加载内容。它的不足在于,对于低版本的浏览器例如ie6不支持hash,需要另外构建一个iframe来记录历史url实现前进和后退。最大的问题,便是#后生成的内容不会被搜索引擎索引到,google之前提供了解决方案,提倡使用#!把地址引导到一个?escape_fragment=url的请求地址中,我在twitter、facebook、人人、新浪微博和已经关闭了的豆瓣说中都看见曾经或正在使用这种hash bang。通过#!来实现无刷新加载的url,由于一般的方法不容易被搜索引擎收录(例如国内百度),称其为dirty url,相对而言,pjax能够使用clean url得到同样效果,并能很好地兼容各种浏览器,是现在最为适合的方法

使用PHP+jQuery实现PJAX

不需要从头编写基于pushState的javascript插件,因为jQuery已有项目把它开源出来,而且很轻易便能实现。目前我已经在开发中的项目里引入,而且很好地在原有的基础上兼容,何况新版微博的推广,我希望让观众看到,我用完之后是这个样子,你们用完之后也会是这个样子

开始前的准备:

1. jQuery libray

2. 基于jQ的pjax插件(github上的开源项目) https://github.com/defunkt/jquery-pjax

3. PHP项目代码(方便分享,本文使用yii框架演示,实际开发中大同小异)

一.前端实现

使用实在简单,而且jquery-pjax这个插件封装得很好,绝对可以按照你的喜好来定制(例如复制g plus的效果),下面是一个整合以上步骤的基本html示例代码:

<?php
Yii::app()->clientScript->registerCoreScript('jquery');
Yii::app()->clientScript->registerScriptFile(Yii::app()->baseUrl . '/js/jquery-pjax/jquery.pjax.js');//具体以你存放pjax的实际位置为准
?>
<p id="nav">
 <a href="<?php echo Yii::app()->createUrl('article/index');?>">article</a>
</p>
<p id="main">替换的内容</p>
<script type="text/javascript">
 $(document).ready(function(){
 $("#main").pjax("a");
 });
</script>

最终的目的,就是点击a标签时,通过ajax返回的结果将id为main的p内的文字替换为相应的地址内容,url自动更新,同时页面不会重新载入。下面开始实现后端要处理的内容

二.PHP端的实现

php端需要处理的任务主要是两件:1.实现layout视图布局 2.判断pjax过来的请求

Yii框架中的实现:

在控制器中对action做如下处理(以Article的index为例):

public function actionIndex() {
 $this->layout = '//layouts/column1';
 $dataProvider = new CActiveDataProvider('Article', array(
 'criteria' => array('order' => 'create_time DESC')
 ));
 if (array_key_exists('HTTP_X_PJAX', $_SERVER) && $_SERVER['HTTP_X_PJAX']) {
 $this->renderPartial('index', array(
 'dataProvider' => $dataProvider,
 ));
 } else {
 $this->render('index', array(
 'dataProvider' => $dataProvider,
 ));
 }
}

效果演示图:

点击article链接或者文章链接后都会出现如下效果页面:

--------------------------------------

jquery-pjax使用中需要注意的事项:

1.返回的模版内容不能为纯文本,需要用html标签包裹

2.插件的使用方法,详情参考github的项目说明,更新后使用方法或有不同

3.对于不支持pushstate的低版本浏览器,pjax插件会自动判断并使用传统的页面加载模式

4.当一个页面的pjax请求时间超过设定时间时,会使用刷新来加载,需要调整插件内的相关参数

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

jquery与php结合实现AJAX长轮询

js ajax加载时的进度条代码

初步了解JavaScript,Ajax,jQuery,并比较三者关系

热心网友 时间:2022-05-15 02:31

最简单的一种方式是,能过JQuery来实现:
例:$.ajax({
url:"a.aspx?a=123",
type:"post",
success:function(data){

}
});
Ajax的原理就是:通过javascript的方式,将前台数据通过xmlhttp对象传递到后台,后台在接收到请求后,将需要的结果,再传回到前台,这样就可以实现不需要页面的回发,页是数据实现来回传递,从页实现无刷新。(全是自己的理解,不是copy的)
例如上面的代码就是,请求a.aspx页面,将查询参数a=123传递给哪个页面后,哪个页面接收到数据,处理完后,如果成功,即进入success函数,里面的data即为回传的值,然后再将 data的内容通过js的控制,让其显示到页面上。
我推荐楼主最好用 jquery框架(轻量很好用),自己完全用js也可以。

上面全是自己的理解,如果哪里有不对,请谅解。
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
电脑wifi已禁用怎么打开电脑无线网络禁用了怎么恢复 ...禁用网络在哪重开win7笔记本无线网络被禁用了怎么办 win7网络禁用怎么恢复 windows7网络被禁用怎么恢复 Win7系统本地连接禁用了怎么恢复Win7系统启动本地连接的两种方法图文... 梦见家人去世什么预兆 ...经缝针现在基本痊愈,一个月过去了现在就是小腿还不能贴大腿,最近感... 小腿缝针拆线三个月了表皮长好了里面的肉怎么有点带黑红色还有点白色... 小腿迎面骨掉快深宽都1厘米左右的肉。当时没缝针。已经20天了。天天... 运费和快递费各走 什么科目? 快递费用放什么科目 javascript无刷新加载一个页面 怎么使用iframe无刷新加载 如何避免幼儿户外活动的安全事故 BCPV-026 出演人叫啥 甲胎蛋白的值是10.2偏高怎么办 怀孕17周甲胎蛋白偏高是怎么回事 孕妇甲胎蛋白偏高是什么原因 孕妇甲胎蛋白高?怎么办 酱牛肉没有高压锅能用电饭锅吗 大男人为什么会这么喜欢看七龙珠拜托了各位 谢谢 为什么龙珠中的boss都是男的? 龙珠中,地球上最强的男人是雅木茶吗? 七龙珠里谁是世界上最强的男人 下水道被硬塑料堵住了,怎么办? 为什么有人觉得《龙珠》中的贝吉塔比起悟空更是好老公,好父亲? 我家卫生间下水道堵塞,是塑料皮,该怎么办 孩子姓李起什么名字好? 农村商业银行是指 我们是怎样开好职工代表大会的? 谁有职工代表大会章程?急! jquery + ajax做的无刷新加载,只有IE显示有问题 web页面无刷新更新内容是通过什么技术实现的 pjax 在a页面无刷新加载b页面 b页面的js脚本为什么不执行呢? jquery无刷新页面js无效的问题 汉语拼音中哪些是前鼻音,哪些是后鼻音 按键精灵 获取网页按钮.click后生成的源码 全民飞机大战拼音怎么写 如何在同一个网页模版下显示不同的内容 asp无刷新显示,更新一部分容 求一段js 页面无刷新显示效果 紫薯糖饼的做法,紫薯糖饼怎么做好吃,紫薯糖饼的家常 紫薯糖饼的做法,紫薯糖饼怎么做好吃,紫薯糖饼 什么查询英语单词的软件比较好? 什么软件查单词又快又好啊? 金山词霸怎么用来查单词? 金山词霸中文为主的词霸 如何在金山词霸中模糊查找单词? python线程和进程的区别 有没有人知道 金山词霸 不用联网就可以查单词的??? 英语单词在线查询