jQuery+PHP發(fā)布的內(nèi)容進(jìn)行無(wú)刷新分頁(yè)(Fckeditor)
這篇文章將使用jQuery,并結(jié)合PHP,將Fckeditor發(fā)布的內(nèi)容進(jìn)行分頁(yè),并且實(shí)現(xiàn)無(wú)刷新切換頁(yè)面。
本文假設(shè)你是WEB開發(fā)人員,掌握了jQuery和PHP相關(guān)知識(shí),并且熟知Fckeditor的配置和使用。
Fckeditor編輯器有一個(gè)插入分頁(yè)符的功能按鈕,點(diǎn)擊該按鈕,將會(huì)在內(nèi)容區(qū)插入一條分頁(yè)符,如下圖紅色框標(biāo)注:

分頁(yè)符對(duì)應(yīng)生成的html代碼是:
<div style="page-break-after: always"><span style="display: none"> </span></div>
我們實(shí)際應(yīng)用情況是這樣的:后臺(tái)通過(guò)Fckeditor編輯器發(fā)布的內(nèi)容,提交到數(shù)據(jù)庫(kù),前臺(tái)通過(guò)PHP鏈接數(shù)據(jù)庫(kù)獲取發(fā)布的內(nèi)容,然后將長(zhǎng)內(nèi)容進(jìn)行分割,并進(jìn)行分頁(yè)。
PHP
PHP將內(nèi)容分割的方法如下:
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編輯器生成的分頁(yè)符代碼,然后PHP通過(guò)preg_split()函數(shù)比對(duì)內(nèi)容,以分隔符為分界點(diǎn),將內(nèi)容分割為多個(gè)page_,并且生成分頁(yè)導(dǎo)航按鈕。使用時(shí)只需調(diào)用pageBreak($content)即可。
CSS
我們通過(guò)CSS來(lái)呈現(xiàn)分頁(yè)按鈕的風(fēng)格,當(dāng)然你可以修改這些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(){
//隱藏所有頁(yè)內(nèi)容
$("#page_break div[id^='page_']").hide();
//顯示當(dāng)前頁(yè)內(nèi)容。
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將分頁(yè)導(dǎo)航按鈕的第一頁(yè)設(shè)置為當(dāng)前狀態(tài),然后通過(guò)單擊分頁(yè)按鈕,切換按鈕的狀態(tài),并且顯示對(duì)應(yīng)頁(yè)的內(nèi)容。
順便說(shuō)一下,文章標(biāo)題說(shuō)的是無(wú)刷新,其實(shí)這不是Ajax的無(wú)刷新效果,而是通過(guò)jQuery控制頁(yè)面內(nèi)容的顯示與隱藏,頁(yè)面內(nèi)容是一次性讀取載入的。
關(guān)于jquery無(wú)刷新分頁(yè)有許多文章,大家可以搜搜之前的文章,或許會(huì)有更大的啟發(fā)。
- PHP中CKEditor和CKFinder配置問(wèn)題小結(jié)
- 針對(duì)PHP環(huán)境下Fckeditor編輯器上傳圖片配置詳細(xì)教程
- 探討fckeditor在Php中的配置詳解
- fckeditor編輯器在php中的配置方法
- php下安裝配置fckeditor編輯器的方法
- php下FCKeditor2.6.5網(wǎng)頁(yè)編輯器的使用方法
- php ckeditor上傳圖片文件名亂碼解決方法
- php fckeditor 調(diào)用的函數(shù)
- fckeditor在php中的用法(添加于修改寫成了函數(shù))
- 將FCKeditor導(dǎo)入PHP+SMARTY的實(shí)現(xiàn)方法
- php版本CKEditor 4和CKFinder安裝及配置方法圖文教程
相關(guān)文章
php處理json格式數(shù)據(jù)經(jīng)典案例總結(jié)
這篇文章主要介紹了php處理json格式數(shù)據(jù)的方法,詳細(xì)講述了json格式數(shù)據(jù)的概念與用法,并結(jié)合經(jīng)典案例總結(jié)分析了php操作json格式數(shù)據(jù)的常用技巧,需要的朋友可以參考下2016-05-05
PHP連續(xù)簽到功能實(shí)現(xiàn)方法詳解
這篇文章主要介紹了PHP連續(xù)簽到功能實(shí)現(xiàn)方法,結(jié)合實(shí)例形式詳細(xì)分析了PHP結(jié)合mysql數(shù)據(jù)庫(kù)實(shí)現(xiàn)連續(xù)簽到功能相關(guān)操作技巧,需要的朋友可以參考下2019-12-12
PHP時(shí)間相關(guān)常用函數(shù)用法示例
這篇文章主要介紹了PHP時(shí)間相關(guān)常用函數(shù)用法,結(jié)合實(shí)例形式詳細(xì)分析了PHP日期時(shí)間函數(shù)常見(jiàn)操作方法與使用注意事項(xiàng),需要的朋友可以參考下2020-06-06
php curl獲取https頁(yè)面內(nèi)容,不直接輸出返回結(jié)果的設(shè)置方法
今天小編就為大家分享一篇php curl獲取https頁(yè)面內(nèi)容,不直接輸出返回結(jié)果的設(shè)置方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-01-01
PHP遠(yuǎn)程連接MYSQL數(shù)據(jù)庫(kù)非常慢的解決方法
如果一個(gè)問(wèn)題出現(xiàn)兩次,那么這個(gè)問(wèn)題就值得去研究下了,上次客戶說(shuō)MYSQL數(shù)據(jù)庫(kù)很慢,我還在想,不會(huì)是PHP的問(wèn)題吧?2008-07-07

