編寫PHP腳本來實現(xiàn)WordPress中評論分頁的功能
方法說明
首先來看看可能被用到的方法. 打開文件 wp-includes/link-template.php 你會發(fā)現(xiàn) WordPress 2.7 多了 4 個針對評論分頁的方法:
- get_comments_pagenum_link
- $pagenum: 頁碼
- $max_page: 最大頁數(shù)
返回鏈接地址. 在本次應(yīng)用中不會被用到, 但大家應(yīng)該知道有這個方法, 將方便你制作插件.
next_comments_link
$label: 顯示的字樣, 默認是 » Newer Comments. 但我一直認為這是 bug, 應(yīng)該是 Newer Comments » 吧?
$max_page: 最大頁數(shù)
顯示跳轉(zhuǎn)到下一頁的鏈接.
previous_comments_link
$label: 顯示的字樣, 默認是 « Older Comments.
顯示跳轉(zhuǎn)到上一頁的鏈接.
paginate_comments_links
$args: 字符串參數(shù)組
- base: 頁面 URL
- format: 我也不知道是什么. 誰能告訴我?
- total: 最大頁數(shù)
- current: 當(dāng)前頁碼
- echo: 是否顯示, 默認為顯示. 不顯示時返回字符串 HTML.
- add_fragment: hash, 默認是 #comments. 為求統(tǒng)一, 方便理解, 也免得修改, 建議制作主題時 評論部分用 id="comments"
顯示評論分頁或返回評論分頁的 HTML.
實例說明
1. 上一頁和下一頁
這是最簡單, 也是最常被提到的, 效果與文章分頁沒什么兩樣.
<div id="commentnavi">
<span class="floatleft"><?php previous_comments_link(__('« Older Comments')) ?></span>
<span class="floatright"><?php next_comments_link(__('Newer Comments »')) ?></span>
<div class="fixed"></div>
</div>
2. 導(dǎo)航式分頁
對訪客最透明, 使用起來最方便的, 效果與使用 WP-PageNavi 分頁的效果相仿.
<div id="commentnavi"> <?php paginate_comments_links(); ?> </div>
看看前面的兩個例子, 好像我們要的功能都可以實現(xiàn)了. 但是你覺不覺得有點怪怪的? 如果后臺中選擇不顯示評論分頁, 或者評論數(shù)不夠分頁, 也要顯示 id="commentnavi" 的外框嗎? 不! 我們要改改這個程序.
可以通過調(diào)用方法 get_option('page_comments') 來獲取后臺的評論分頁選項.
我們還可以調(diào)用方法 paginate_comments_links('echo=0') 來知道評論是否足夠并需要進行分頁處理.
3. 上一頁和下一頁 (改進)
<?php
// 如果用戶在后臺選擇要顯示評論分頁
if (get_option('page_comments')) {
// 獲取評論分頁的 HTML
$comment_pages = paginate_comments_links('echo=0');
// 如果評論分頁的 HTML 不為空, 顯示上一頁和下一頁的鏈接
if ($comment_pages) {
?>
<div id="commentnavi">
<span class="floatleft"><?php previous_comments_link(__('« Older Comments')) ?></span>
<span class="floatright"><?php next_comments_link(__('Newer Comments »')) ?></span>
<div class="fixed"></div>
</div>
<?php
}
}
?>
4. 導(dǎo)航式分頁 (改進)
<?php
// 如果用戶在后臺選擇要顯示評論分頁
if (get_option('page_comments')) {
// 獲取評論分頁的 HTML
$comment_pages = paginate_comments_links('echo=0');
// 如果評論分頁的 HTML 不為空, 顯示導(dǎo)航式分頁
if ($comment_pages) {
?>
<div id="commentnavi">
<?php echo $comment_pages; ?>
</div>
<?php
}
}
?>
對于最新的評論分頁功能, 我有點自己的看法, 也隨便說一下吧.
評論分頁并不完美. 如果外面某個鏈接轉(zhuǎn)跳到 http://www.example.com/#5630, 但是編號為 5630 的評論并不在第一頁, 那么就無法定位到這條評論上面, 轉(zhuǎn)跳過來的兄弟的感覺會比較不爽.
另外, WordPress 的評論分頁不是 AJAX 應(yīng)用 (為瀏覽器的兼容性考慮, 以后也不太可能是), 所以翻頁會相當(dāng)耗時. 所以我建議, 就算要分頁, 也要將每頁顯示的評論數(shù)設(shè)大一點. 30? 50? 100? 因博而異.
好了, 大概你已經(jīng)知道該怎么使用了? CSS 就不多說了, 各有所好嘛, 這個不好說.
- 使用CDN和AJAX加速WordPress中jQuery的加載
- WordPress JQuery處理沙發(fā)頭像
- 利用jQuery實現(xiàn)WordPress中@的ID懸浮顯示評論內(nèi)容
- 詳解WordPress中調(diào)用評論模板和循環(huán)輸出評論的PHP函數(shù)
- WordPress中鼠標(biāo)懸停顯示和隱藏評論及引用按鈕的實現(xiàn)
- 解決WordPress使用CDN后博文無法評論的錯誤
- 優(yōu)化WordPress中文章與評論的時間顯示
- 在WordPress中實現(xiàn)評論頭像的自定義默認和延遲加載
- WordPress中利用AJAX異步獲取評論用戶頭像的方法
- WordPress中限制非管理員用戶在文章后只能評論一次
- 使用jQuery實現(xiàn)WordPress中的Ctrl+Enter和@評論回復(fù)
相關(guān)文章
php圖像處理函數(shù)imagecopyresampled用法詳解
這篇文章主要介紹了php圖像處理函數(shù)imagecopyresampled用法,結(jié)合實例形式詳細分析了imagecopyresampled函數(shù)的功能、參數(shù)、使用方法,需要的朋友可以參考下2016-12-12
[企業(yè)公眾號]升級到[企業(yè)微信]之后發(fā)送消息失敗的解決方法
這篇文章主要介紹了[企業(yè)公眾號]升級到[企業(yè)微信]之后發(fā)送消息失敗的解決方法,涉及微信接口的修改相關(guān)操作,需要的朋友可以參考下2017-06-06

