使用jQuery和PHP將Fckeditor發布的內容進行無重新整理分頁

來源:互聯網
上載者:User

 

Fckeditor是一款所見即所得 (WYSIWYG)的WEB編輯器,它常被用作後台編輯發布資訊。當要發布的內容很多很長時,就要考慮前台顯示的分頁效果了,本文將使用jQuery,並結合PHP,將Fckeditor發布的內容進行分頁,並且實現無重新整理切換頁面。

關於Fckeditor使用,筆者不想多言。本文假設你是WEB開發人員,掌握了jQuery和PHP相關知識,並且熟知Fckeditor的配置和使用。

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控制頁面內容的顯示與隱藏,頁面內容是一次性讀取載入的。



相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.