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

Fckeditor是一款所见即所得的WEB编辑器,它常被用作后台编辑发布信息。当要发布的内容很多很长时,就要考虑前台显示的分页效果了,本文将使用jQuery,并结合PHP,将Fckeditor发布的内容进行分页,并且实现无刷新切换页面。

关于Fckeditor使用,笔者不想多言。本文假设你是WEB开发人员,掌握了jQuery和PHP相关知识,并且熟知Fckeditor的配置和使用。

Fckeditor编辑器有一个插入分页符的功能按钮,点击该按钮,将会在内容区插入一条分页符,如下图红色框标注:

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

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

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

PHP

PHP将内容分割的方法如下:

  1. function pageBreak($content){ 
  2.     $content  = $content; 
  3.     $pattern  = "/<div style=\"page-break-after: always\"><span style=\"display: none\">  
  4. <\/span><\/div>/"; 
  5.     $strSplit = preg_split($pattern, $content, -1, PREG_SPLIT_NO_EMPTY); 
  6.     $count    = count($strSplit); 
  7.     $outStr   = ""
  8.     $i        = 1; 
  9.  
  10.     if ($count > 1 ) { 
  11.         $outStr   = "<div id='page_break'>"
  12.         foreach($strSplit as $value) { 
  13.             if ($i <= 1) { 
  14.                 $outStr .= "<div id='page_$i'>$value</div>"
  15.             } else { 
  16.                 $outStr .= "<div id='page_$i' class='collapse'>$value</div>"
  17.             } 
  18.             $i++; 
  19.         } 
  20.  
  21.         $outStr .= "<div class='num'>"
  22.         for ($i = 1; $i <= $count; $i++) { 
  23.             $outStr .= "<li>$i</li>"
  24.         } 
  25.         $outStr .= "</div></div>"
  26.         return $outStr; 
  27.     } else { 
  28.         return $content; 
  29.     } 

可以看出啦,上述代码中的$pattern就是Fckeditor编辑器生成的分页符代码,然后PHP通过preg_split()函数比对内容,以分隔符为分界点,将内容分割为多个page_,并且生成分页导航按钮。使用时只需调用pageBreak($content)即可。

CSS

我们通过CSS来呈现分页按钮的风格,当然你可以修改这些CSS,定制你想要的外观。

  1. #page_break {} 
  2. #page_break .collapse {displaynone;} 
  3. #page_break .num {padding10px 0;text-aligncenter;} 
  4. #page_break .num li{displayinlinemargin0 2px;padding3px 5px;border:1px solid #abcee4
  5. background-color#fff;color#369;text-aligncenter;cursorpointer;overflowhidden;} 
  6. #page_break .num li.on{background-color#369;color#fff;font-weightbold;} 

jQuery

  1. $(function(){ 
  2.     $('#page_break .num li:first').addClass('on'); 
  3.  
  4.     $('#page_break .num li').click(function(){ 
  5.         //隐藏所有页内容 
  6.         $("#page_break div[id^='page_']").hide(); 
  7.  
  8.         //显示当前页内容。 
  9.         if ($(this).hasClass('on')) { 
  10.             $('#page_break #page_' + $(this).text()).show(); 
  11.         } else { 
  12.             $('#page_break .num li').removeClass('on'); 
  13.             $(this).addClass('on'); 
  14.             $('#page_break #page_' + $(this).text()).fadeIn('normal'); 
  15.         } 
  16.     }); 
  17. }); 

我们使用jQuery将分页导航按钮的第一页设置为当前状态,然后通过单击分页按钮,切换按钮的状态,并且显示对应页的内容。请看。

顺便说一下,文章标题说的是无刷新,其实这不是Ajax的无刷新效果,而是通过jQuery控制页面内容的显示与隐藏,页面内容是一次性读取载入的。

转载请注明:代码家园 » jQuery+PHP使Fckeditor发布的内容进行无刷新分页

评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)