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
用Zend Encode编写开发PHP程序
Oct 09 PHP
劣质的PHP代码简化
Feb 08 PHP
php自定义函数之递归删除文件及目录
Aug 08 PHP
php-cli简介(不会Shell语言一样用Shell)
Jun 03 PHP
完美解决令人抓狂的zend studio 7代码提示(content Assist)速度慢的问题
Jun 20 PHP
php字符编码转换之gb2312转为utf8
Oct 28 PHP
使用PHP破解防盗链图片的一个简单方法
Jun 07 PHP
php学习笔记之基础知识
Nov 08 PHP
PHP水印类,支持添加图片、文字、填充颜色区域的实现
Feb 04 PHP
LaravelS通过Swoole加速Laravel/Lumen详解
Mar 02 PHP
Yii框架学习笔记之应用组件操作示例
Nov 13 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
分享下php5类中三种数据类型的区别
2015/01/26 PHP
Laravel 5.5基于内置的Auth模块实现前后台登陆详解
2017/12/21 PHP
php桥接模式应用案例分析
2019/10/23 PHP
html中的input标签的checked属性jquery判断代码
2012/09/19 Javascript
javascript 实现键盘上下左右功能的小例子
2013/09/15 Javascript
JS JSON对象转为字符串的简单实现方法
2013/11/18 Javascript
jquery与prototype框架的详细对比
2013/11/21 Javascript
ExtJS4中的requires使用方法示例介绍
2013/12/03 Javascript
jquery移除了live()、die(),新版事件绑定on()、off()的方法
2016/10/26 Javascript
详解Jquery EasyUI tree 的异步加载(遍历指定文件夹,根据文件夹内的文件生成tree)
2017/02/11 Javascript
详解webpack2+React 实例demo
2017/09/11 Javascript
vue引入jq插件的实例讲解
2017/09/12 Javascript
Vue.js实现列表清单的操作方法
2017/11/15 Javascript
JS高级技巧(简洁版)
2018/07/29 Javascript
vue中使用vee-validator完成表单校验方案
2019/11/01 Javascript
关于vue里页面的缓存详解
2019/11/04 Javascript
Vue父子组件传值的一些坑
2020/09/16 Javascript
Vue使用CDN引用项目组件,减少项目体积的步骤
2020/10/30 Javascript
[01:23:45]DOTA2-DPC中国联赛 正赛 CDEC vs Dragon BO3 第一场 1月22日
2021/03/11 DOTA
videocapture库制作python视频高速传输程序
2013/12/23 Python
Python中的is和id用法分析
2015/01/26 Python
Python实现竖排打印传单手机号码易撕条
2015/03/16 Python
Python下的常用下载安装工具pip的安装方法
2015/11/13 Python
Python聊天室实例程序分享
2016/01/05 Python
python获取微信小程序手机号并绑定遇到的坑
2018/11/19 Python
全球酒店比价网:HotelsCombined
2017/06/20 全球购物
Habitat家居英国官方网站:沙发、家具、照明、厨房和户外
2019/12/12 全球购物
长曲棍球装备:Lacrosse Monkey
2020/12/02 全球购物
大学生毕业求职找工作的自我评价
2013/09/29 职场文书
《小松树和大松树》教学反思
2014/02/20 职场文书
英语系毕业生求职信
2014/07/13 职场文书
幼儿园见习报告
2014/10/30 职场文书
七年级地理教学计划
2015/01/22 职场文书
文艺部部长竞选稿
2015/11/21 职场文书
redis 存储对象的方法对比分析
2021/08/02 Redis
使用Spring处理x-www-form-urlencoded方式
2021/11/02 Java/Android