服务器之家

服务器之家 > 正文

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

时间:2020-11-26 15:18     来源/作者:PHP编程实例

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

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

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

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

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
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,定制你想要的外观。

?
1
2
3
4
5
6
#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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
$(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无刷新分页有许多文章,大家可以搜搜之前的文章,或许会有更大的启发。

标签:

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
Intellij idea2020永久破解,亲测可用!!!
Intellij idea2020永久破解,亲测可用!!! 2020-07-29
歪歪漫画vip账号共享2020_yy漫画免费账号密码共享
歪歪漫画vip账号共享2020_yy漫画免费账号密码共享 2020-04-07
电视剧《琉璃》全集在线观看 琉璃美人煞1-59集免费观看地址
电视剧《琉璃》全集在线观看 琉璃美人煞1-59集免费观看地址 2020-08-12
最新idea2020注册码永久激活(激活到2100年)
最新idea2020注册码永久激活(激活到2100年) 2020-07-29
返回顶部