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目录导航文件代码
Oct 09 PHP
php面向对象全攻略 (五) 封装性
Sep 30 PHP
发一个php简单的伪原创程序,配合商城采集用的
Oct 12 PHP
PHP中调用ASP.NET的WebService的代码
Apr 22 PHP
解析file_get_contents模仿浏览器头(user_agent)获取数据
Jun 27 PHP
php ci框架中加载css和js文件失败的解决方法
Mar 03 PHP
PHP中遇到BOM、编码导致json_decode函数无法解析问题
Jul 02 PHP
Linux下PHP安装mcrypt扩展模块笔记
Sep 10 PHP
php 魔术方法详解
Nov 11 PHP
PHP实现简单搜歌的方法
Jul 28 PHP
Laravel框架模板加载,分配变量及简单路由功能示例
Jun 11 PHP
thinkPHP5框架auth权限控制类与用法示例
Jun 12 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
一个用php3编写的简单计数器
2006/10/09 PHP
PHP编程中八种常见的文件操作方式
2006/11/19 PHP
php分页思路以及在ZF中的使用
2012/05/30 PHP
THINKPHP项目开发中的日志记录实例分析
2014/12/01 PHP
ZendFramework框架实现连接两个或多个数据库的方法
2016/12/08 PHP
php 浮点数比较方法详解
2017/05/05 PHP
php实现微信分享朋友链接功能
2019/02/18 PHP
JavaScript中的类继承
2010/11/25 Javascript
js遍历子节点子元素附属性及方法
2014/08/19 Javascript
Jquery $.getJSON 在IE下的缓存问题解决方法
2014/10/10 Javascript
jquery实现仿新浪微博评论滚动效果
2015/08/06 Javascript
详解jQuery移动页面开发中的ui-grid网格布局使用
2015/12/03 Javascript
再谈javascript常见错误及解决方法
2016/09/16 Javascript
详解Javascript数据类型的转换规则
2016/12/12 Javascript
JavaScript 获取元素在父节点中的下标(推荐)
2017/06/28 Javascript
VUE中v-on:click事件中获取当前dom元素的代码
2018/08/22 Javascript
通过实例讲解JS如何防抖动
2019/06/15 Javascript
Paypal支付不完全指北
2020/06/04 Javascript
Vue触发input选取文件点击事件操作
2020/08/07 Javascript
openLayer4实现动态改变标注图标
2020/08/17 Javascript
Python实现监控程序执行时间并将其写入日志的方法
2015/06/30 Python
Python实现账号密码输错三次即锁定功能简单示例
2019/03/29 Python
PyTorch中反卷积的用法详解
2019/12/30 Python
使用keras实现Precise, Recall, F1-socre方式
2020/06/15 Python
django教程如何自学
2020/07/31 Python
LivingSocial爱尔兰:爱尔兰本地优惠
2018/08/10 全球购物
Fenty Beauty官网:蕾哈娜创立的美妆品牌
2021/01/07 全球购物
数据库什么时候应该被重组
2012/11/02 面试题
鼓励运动员的广播稿
2014/02/08 职场文书
三八活动策划方案
2014/08/17 职场文书
党的群众路线教育实践活动整改方案
2014/10/28 职场文书
商铺租房协议书范本
2014/12/04 职场文书
2015年医院创卫工作总结
2015/04/22 职场文书
2019个人工作总结
2019/06/21 职场文书
Apache Calcite 实现方言转换的代码
2021/04/24 Servers
Java 垃圾回收超详细讲解记忆集和卡表
2022/04/08 Java/Android