jQuery+PHP发布的内容进行无刷新分页(Fckeditor)


Posted in PHP onOctober 22, 2015

这篇文章将使用jQuery,并结合PHP,将Fckeditor发布的内容进行分页,并且实现无刷新切换页面。
 本文假设你是WEB开发人员,掌握了jQuery和PHP相关知识,并且熟知Fckeditor的配置和使用。
Fckeditor编辑器有一个插入分页符的功能按钮,点击该按钮,将会在内容区插入一条分页符,如下图红色框标注:

jQuery+PHP发布的内容进行无刷新分页(Fckeditor)

分页符对应生成的html代码是:

<div style="page-break-after: always"><span style="display: none"> </span></div>

我们实际应用情况是这样的:后台通过Fckeditor编辑器发布的内容,提交到数据库,前台通过PHP链接数据库获取发布的内容,然后将长内容进行分割,并进行分页。
PHP
PHP将内容分割的方法如下:

function pageBreak($content){ 
 $content = $content; 
 $pattern = "/<div style=\"page-break-after: always\"><span style=\"display: none\"> 
<\/span><\/div>/"; 
 $strSplit = preg_split($pattern, $content, -1, PREG_SPLIT_NO_EMPTY); 
 $count = count($strSplit); 
 $outStr = ""; 
 $i  = 1; 
 
 if ($count > 1 ) { 
  $outStr = "<div id='page_break'>"; 
  foreach($strSplit as $value) { 
   if ($i <= 1) { 
    $outStr .= "<div id='page_$i'>$value</div>"; 
   } else { 
    $outStr .= "<div id='page_$i' class='collapse'>$value</div>"; 
   } 
   $i++; 
  } 
 
  $outStr .= "<div class='num'>"; 
  for ($i = 1; $i <= $count; $i++) { 
   $outStr .= "<li>$i</li>"; 
  } 
  $outStr .= "</div></div>"; 
  return $outStr; 
 } else { 
  return $content; 
 } 
}

可以看出啦,上述代码中的$pattern就是Fckeditor编辑器生成的分页符代码,然后PHP通过preg_split()函数比对内容,以分隔符为分界点,将内容分割为多个page_,并且生成分页导航按钮。使用时只需调用pageBreak($content)即可。
CSS
我们通过CSS来呈现分页按钮的风格,当然你可以修改这些CSS,定制你想要的外观。

#page_break {} 
#page_break .collapse {display: none;} 
#page_break .num {padding: 10px 0;text-align: center;} 
#page_break .num li{display: inline; margin: 0 2px;padding: 3px 5px;border:1px solid #abcee4; 
background-color: #fff;color: #369;text-align: center;cursor: pointer;overflow: hidden;} 
#page_break .num li.on{background-color: #369;color: #fff;font-weight: bold;}

jQuery

$(function(){ 
 $('#page_break .num li:first').addClass('on'); 
 
 $('#page_break .num li').click(function(){ 
  //隐藏所有页内容 
  $("#page_break div[id^='page_']").hide(); 
 
  //显示当前页内容。 
  if ($(this).hasClass('on')) { 
   $('#page_break #page_' + $(this).text()).show(); 
  } else { 
   $('#page_break .num li').removeClass('on'); 
   $(this).addClass('on'); 
   $('#page_break #page_' + $(this).text()).fadeIn('normal'); 
  } 
 }); 
});

我们使用jQuery将分页导航按钮的第一页设置为当前状态,然后通过单击分页按钮,切换按钮的状态,并且显示对应页的内容。
顺便说一下,文章标题说的是无刷新,其实这不是Ajax的无刷新效果,而是通过jQuery控制页面内容的显示与隐藏,页面内容是一次性读取载入的。

关于jquery无刷新分页有许多文章,大家可以搜搜之前的文章,或许会有更大的启发。

PHP 相关文章推荐
php获取mysql版本的几种方法小结
Mar 25 PHP
Zend Guard一些常见问题解答
Sep 11 PHP
php xml-rpc远程调用
Dec 19 PHP
PHP 检查扩展库或函数是否可用的代码
Apr 06 PHP
discuz程序的PHP加密函数原理分析
Aug 05 PHP
php根据年月获取季度的方法
Mar 31 PHP
C#静态方法与非静态方法实例分析
Sep 22 PHP
PHP实现模仿socket请求返回页面的方法
Nov 04 PHP
PHP实现微信发红包程序
Aug 24 PHP
超详细的php用户注册页面填写信息完整实例(附源码)
Nov 17 PHP
Laravel路由研究之domain解决多域名问题的方法示例
Apr 04 PHP
PHP实现的微信APP支付功能示例【基于TP5框架】
Sep 16 PHP
PHP+Mysql+jQuery查询和列表框选择操作实例讲解
Oct 22 #PHP
PHP实现无限级分类(不使用递归)
Oct 22 #PHP
PHP实现递归无限级分类
Oct 22 #PHP
php防止网站被攻击的应急代码
Oct 21 #PHP
PHP统计当前在线用户数实例讲解
Oct 21 #PHP
php精确的统计在线人数的方法
Oct 21 #PHP
为你总结一些php信息函数
Oct 21 #PHP
You might like
单台服务器的PHP进程之间实现共享内存的方法
2014/06/13 PHP
PHP的error_reporting错误级别变量对照表
2014/07/08 PHP
php自动提交表单的方法(基于fsockopen与curl)
2016/05/09 PHP
php操作路径的经典方法(必看篇)
2016/10/04 PHP
CentOS7.0下安装PHP5.6.30服务的教程详解
2018/09/29 PHP
Ruffy javascript 学习笔记
2009/11/30 Javascript
javascript 循环读取JSON数据的代码
2010/07/17 Javascript
jquery实现点击弹出层效果的简单实例
2014/03/03 Javascript
JavaScript实现数据类型的相互转换
2016/03/06 Javascript
JS实现间歇滚动的运动效果实例
2016/12/22 Javascript
js学习总结_轮播图之渐隐渐现版(实例讲解)
2017/07/17 Javascript
Vue自定义指令详解
2017/07/28 Javascript
H5+C3+JS实现双人对战五子棋游戏(UI篇)
2020/05/28 Javascript
使用vue-cli3新建一个项目并写好基本配置(推荐)
2019/04/24 Javascript
微信小程序实现拖拽功能
2019/09/26 Javascript
如何利用JavaScript编写更好的条件语句详解
2020/08/10 Javascript
浅析 Vue 3.0 的组装式 API(一)
2020/08/31 Javascript
原生js实现俄罗斯方块
2020/10/20 Javascript
Python编写登陆接口的方法
2017/07/10 Python
Python内建函数之raw_input()与input()代码解析
2017/10/26 Python
http请求 request失败自动重新尝试代码示例
2018/01/25 Python
python和shell获取文本内容的方法
2018/06/05 Python
解决Pycharm出现的部分快捷键无效问题
2018/10/22 Python
解决python给列表里添加字典时被最后一个覆盖的问题
2019/01/21 Python
Python查找数组中数值和下标相等的元素示例【二分查找】
2019/02/13 Python
使用Python将Mysql的查询数据导出到文件的方法
2019/02/25 Python
利用pandas合并多个excel的方法示例
2019/10/10 Python
pytorch的batch normalize使用详解
2020/01/15 Python
如何基于线程池提升request模块效率
2020/04/18 Python
python 利用matplotlib在3D空间中绘制平面的案例
2021/02/06 Python
高中生评语大全
2014/04/25 职场文书
运动会广播稿200米(5篇)
2014/10/15 职场文书
2014年统战工作总结
2014/12/09 职场文书
酒桌上的祝酒词
2015/08/12 职场文书
深入解析MySQL索引数据结构
2021/10/16 MySQL
阿里云服务器部署RabbitMQ集群的详细教程
2022/06/01 Servers