为自定义文章类型添加筛选功能

  • A+
所属分类:建博笔记

开篇说明

  • 本文针对begin主题原有的筛选功能进行扩展,因此非该主题的童鞋本文仅供参考
  • 之前的文章:begin主题筛选功能增加筛选项 的侧重点是为已有内置文章类型下的筛选功能添加筛选项,本文的侧重点是为自定义文章类型:视频(video)新增筛选功能
  • 理论上本文的操作过程可以单独实现,但考虑到在此之前我已对原有的筛选功能进行过修改(主要是代码结构发生变化影响到本文所涉及的代码的调用和位置关系),因此建议在学习本文之前最好可以先阅读一下之前的那篇文章
  • 本文提到的代码位置都是针对修改后的位置而言
  • 本文篇幅较长过程较为复杂,特别是最后缩略图部分略显繁琐甚至啰嗦,请务必仔细阅读,好好理解
  • 本文涉及的文件较多,因此在修改前务必备份好相应的文件

 

预期实现的功能

  1. 不同文章类型分别使用不同的筛选条件
  2. 不同文章类型下的筛选结果页可以分别设置不同的布局(列表和图片布局)
  3. 不同文章类型下的筛选条件不重复调用,主要是避免筛选列表中出现不符合当前筛选环境的筛选标签

 

最终效果预览

 

第一部分:后台相关功能的实现

一、主题选项中追加筛选条件和筛选结果页布局选项

首先:打开inc/options/begin-options.php文件,大约4622~4628行的位置,找到代码

  1. $options[] = array(
  2. 'name' => '分类ID对照',
  3. 'desc' => '<ul>'.$cats_id.'</ul>',
  4. 'id' => 'catids',
  5. 'class' => 'fi-catid hidden',
  6. 'type' => 'info'
  7. );

将其移动到代码(大约4604~4611行的位置)

  1. $options[] = array(
  2. 'name' => '',
  3. 'desc' => '输入显示筛选的分类ID,多个分类用英文半角逗号","隔开',
  4. 'id' => 'filter_id',
  5. 'class' => 'hidden',
  6. 'std' => '1,2',
  7. 'type' => 'text'
  8. );

下面

这一步的目的是:重新布局多条件筛选下的筛选功能。

然后:在上面提到的这两段代码的下面添加

  1. $options[] = array(
  2. 'name' => '',
  3. 'desc' => '',
  4. 'id' => 'filters_va',
  5. 'class' => 'fia-catid hidden',
  6. 'std' => '1',
  7. 'type' => 'checkbox'
  8. );
  9. $options[] = array(
  10. 'name' => '',
  11. 'desc' => '筛选VA文字,用于自定义文章类型:视频',
  12. 'id' => 'filters_va_t',
  13. 'class' => 'hidden',
  14. 'std' => '类 别',
  15. 'type' => 'text'
  16. );
  17. $options[] = array(
  18. 'name' => '',
  19. 'desc' => '',
  20. 'id' => 'filters_vb',
  21. 'class' => 'fia-catid hidden',
  22. 'std' => '1',
  23. 'type' => 'checkbox'
  24. );
  25. $options[] = array(
  26. 'name' => '',
  27. 'desc' => '筛选VB文字,用于自定义文章类型:视频',
  28. 'id' => 'filters_vb_t',
  29. 'class' => 'hidden',
  30. 'std' => '语 言',
  31. 'type' => 'text'
  32. );
  33. $options[] = array(
  34. 'name' => '',
  35. 'desc' => '',
  36. 'id' => 'filters_vc',
  37. 'class' => 'fia-catid hidden',
  38. 'std' => '1',
  39. 'type' => 'checkbox'
  40. );
  41. $options[] = array(
  42. 'name' => '',
  43. 'desc' => '筛选VC文字,用于自定义文章类型:视频',
  44. 'id' => 'filters_vc_t',
  45. 'class' => 'hidden',
  46. 'std' => '字 幕',
  47. 'type' => 'text'
  48. );
  49. $options[] = array(
  50. 'name' => '',
  51. 'desc' => '',
  52. 'id' => 'filters_vd',
  53. 'class' => 'fia-catid hidden',
  54. 'std' => '1',
  55. 'type' => 'checkbox'
  56. );
  57. $options[] = array(
  58. 'name' => '',
  59. 'desc' => '筛选VD文字,用于自定义文章类型:视频',
  60. 'id' => 'filters_vd_t',
  61. 'class' => 'hidden',
  62. 'std' => '水 印',
  63. 'type' => 'text'
  64. );
  65. $options[] = array(
  66. 'name' => '',
  67. 'desc' => '',
  68. 'id' => 'filters_ve',
  69. 'class' => 'fia-catid hidden',
  70. 'std' => '1',
  71. 'type' => 'checkbox'
  72. );
  73. $options[] = array(
  74. 'name' => '',
  75. 'desc' => '筛选VE文字,用于自定义文章类型:视频',
  76. 'id' => 'filters_ve_t',
  77. 'class' => 'hidden',
  78. 'std' => '清晰度',
  79. 'type' => 'text'
  80. );

代码说明:

  • 因为我需要用到五个筛选条件,所以加了五个选项(下同,不再赘述)
  • 筛选条件以每两段代码为一组,如果你要增删筛选条件,请按组操作
  • descidstd后面的文字可以根据自己的情况修改,但要注意和后面的代码对应上

接着:将代码(在上面所有代码的下面)

  1. $options[] = array(
  2. 'name' => '',
  3. 'desc' => '筛选结果使用图片布局',
  4. 'id' => 'filters_img',
  5. 'class' => 'hidden',
  6. 'std' => '0',
  7. 'type' => 'checkbox'
  8. );

中的

  1. 'desc' => '筛选结果使用图片布局',

替换

  1. 'desc' => '仅勾选此项可单独针对“内置文章类型”筛选结果使用图片布局',

代码作用:

  • 主要是为了区分接下来将要添加的另一个筛选结果页布局选项
  • 通过这两个选项来实现单独控制筛选结果页布局(列表和图片布局)的目的

最后:在上面所有代码的下面添加

  1. $options[] = array(
  2. 'name' => '',
  3. 'desc' => '仅勾选此项可单独针对“自定义文章类型:视频”筛选结果使用图片布局',
  4. 'id' => 'filters_img_v',
  5. 'class' => 'hidden',
  6. 'std' => '0',
  7. 'type' => 'checkbox'
  8. );

代码作用:

  • 配合原有的筛选结果页布局选项,实现“不同文章类型下的筛选结果页显示不同布局”的目的

完成上面“步骤一”中的操作后,这个文件中关于筛选部分的完整代码应该是这样的:展开

  1. $options[] = array(
  2. 'name' => '多条件筛选',
  3. 'desc' => '启用',
  4. 'id' => 'filters',
  5. 'class' => 'be_ico',
  6. 'std' => '1',
  7. 'type' => 'checkbox'
  8. );
  9. $options[] = array(
  10. 'name' => '',
  11. 'desc' => '',
  12. 'id' => 'filters_a',
  13. 'class' => 'fia-catid hidden',
  14. 'std' => '1',
  15. 'type' => 'checkbox'
  16. );
  17. $options[] = array(
  18. 'name' => '',
  19. 'desc' => '筛选A文字,用于内置文章类型',
  20. 'id' => 'filters_a_t',
  21. 'class' => 'hidden',
  22. 'std' => '影片类别',
  23. 'type' => 'text'
  24. );
  25. $options[] = array(
  26. 'name' => '',
  27. 'desc' => '',
  28. 'id' => 'filters_b',
  29. 'class' => 'fia-catid hidden',
  30. 'std' => '1',
  31. 'type' => 'checkbox'
  32. );
  33. $options[] = array(
  34. 'name' => '',
  35. 'desc' => '筛选B文字,用于内置文章类型',
  36. 'id' => 'filters_b_t',
  37. 'class' => 'hidden',
  38. 'std' => '风格类型',
  39. 'type' => 'text'
  40. );
  41. $options[] = array(
  42. 'name' => '',
  43. 'desc' => '',
  44. 'id' => 'filters_c',
  45. 'class' => 'fia-catid hidden',
  46. 'std' => '1',
  47. 'type' => 'checkbox'
  48. );
  49. $options[] = array(
  50. 'name' => '',
  51. 'desc' => '筛选C文字,用于内置文章类型',
  52. 'id' => 'filters_c_t',
  53. 'class' => 'hidden',
  54. 'std' => '上映年代',
  55. 'type' => 'text'
  56. );
  57. $options[] = array(
  58. 'name' => '',
  59. 'desc' => '',
  60. 'id' => 'filters_d',
  61. 'class' => 'fia-catid hidden',
  62. 'std' => '1',
  63. 'type' => 'checkbox'
  64. );
  65. $options[] = array(
  66. 'name' => '',
  67. 'desc' => '筛选D文字,用于内置文章类型',
  68. 'id' => 'filters_d_t',
  69. 'class' => 'hidden',
  70. 'std' => '国家地区',
  71. 'type' => 'text'
  72. );
  73. $options[] = array(
  74. 'name' => '',
  75. 'desc' => '',
  76. 'id' => 'filters_e',
  77. 'class' => 'fia-catid hidden',
  78. 'std' => '1',
  79. 'type' => 'checkbox'
  80. );
  81. $options[] = array(
  82. 'name' => '',
  83. 'desc' => '筛选E文字,用于内置文章类型',
  84. 'id' => 'filters_e_t',
  85. 'class' => 'hidden',
  86. 'std' => '清晰程度',
  87. 'type' => 'text'
  88. );
  89. $options[] = array(
  90. 'name' => '',
  91. 'desc' => '',
  92. 'id' => 'filters_f',
  93. 'class' => 'fia-catid hidden',
  94. 'std' => '1',
  95. 'type' => 'checkbox'
  96. );
  97. $options[] = array(
  98. 'name' => '',
  99. 'desc' => '筛选F文字,用于内置文章类型',
  100. 'id' => 'filters_f_t',
  101. 'class' => 'hidden',
  102. 'std' => '更新状态',
  103. 'type' => 'text'
  104. );
  105. $options[] = array(
  106. 'name' => '',
  107. 'desc' => '输入显示筛选的分类ID,多个分类用英文半角逗号","隔开',
  108. 'id' => 'filter_id',
  109. 'class' => 'hidden',
  110. 'std' => '1,2',
  111. 'type' => 'text'
  112. );
  113. $options[] = array(
  114. 'name' => '分类ID对照',
  115. 'desc' => '<ul>'.$cats_id.'</ul>',
  116. 'id' => 'catids',
  117. 'class' => 'fi-catid hidden',
  118. 'type' => 'info'
  119. );
  120. $options[] = array(
  121. 'name' => '',
  122. 'desc' => '',
  123. 'id' => 'filters_va',
  124. 'class' => 'fia-catid hidden',
  125. 'std' => '1',
  126. 'type' => 'checkbox'
  127. );
  128. $options[] = array(
  129. 'name' => '',
  130. 'desc' => '筛选VA文字,用于自定义文章类型:视频',
  131. 'id' => 'filters_va_t',
  132. 'class' => 'hidden',
  133. 'std' => '类 别',
  134. 'type' => 'text'
  135. );
  136. $options[] = array(
  137. 'name' => '',
  138. 'desc' => '',
  139. 'id' => 'filters_vb',
  140. 'class' => 'fia-catid hidden',
  141. 'std' => '1',
  142. 'type' => 'checkbox'
  143. );
  144. $options[] = array(
  145. 'name' => '',
  146. 'desc' => '筛选VB文字,用于自定义文章类型:视频',
  147. 'id' => 'filters_vb_t',
  148. 'class' => 'hidden',
  149. 'std' => '语 言',
  150. 'type' => 'text'
  151. );
  152. $options[] = array(
  153. 'name' => '',
  154. 'desc' => '',
  155. 'id' => 'filters_vc',
  156. 'class' => 'fia-catid hidden',
  157. 'std' => '1',
  158. 'type' => 'checkbox'
  159. );
  160. $options[] = array(
  161. 'name' => '',
  162. 'desc' => '筛选VC文字,用于自定义文章类型:视频',
  163. 'id' => 'filters_vc_t',
  164. 'class' => 'hidden',
  165. 'std' => '字 幕',
  166. 'type' => 'text'
  167. );
  168. $options[] = array(
  169. 'name' => '',
  170. 'desc' => '',
  171. 'id' => 'filters_vd',
  172. 'class' => 'fia-catid hidden',
  173. 'std' => '1',
  174. 'type' => 'checkbox'
  175. );
  176. $options[] = array(
  177. 'name' => '',
  178. 'desc' => '筛选VD文字,用于自定义文章类型:视频',
  179. 'id' => 'filters_vd_t',
  180. 'class' => 'hidden',
  181. 'std' => '水 印',
  182. 'type' => 'text'
  183. );
  184. $options[] = array(
  185. 'name' => '',
  186. 'desc' => '',
  187. 'id' => 'filters_ve',
  188. 'class' => 'fia-catid hidden',
  189. 'std' => '1',
  190. 'type' => 'checkbox'
  191. );
  192. $options[] = array(
  193. 'name' => '',
  194. 'desc' => '筛选VE文字,用于自定义文章类型:视频',
  195. 'id' => 'filters_ve_t',
  196. 'class' => 'hidden',
  197. 'std' => '清晰度',
  198. 'type' => 'text'
  199. );
  200. $options[] = array(
  201. 'name' => '',
  202. 'desc' => '仅勾选此项可单独针对“内置文章类型”筛选结果使用图片布局',
  203. 'id' => 'filters_img',
  204. 'class' => 'hidden',
  205. 'std' => '0',
  206. 'type' => 'checkbox'
  207. );
  208. $options[] = array(
  209. 'name' => '',
  210. 'desc' => '仅勾选此项可单独针对“自定义文章类型:视频”筛选结果使用图片布局',
  211. 'id' => 'filters_img_v',
  212. 'class' => 'hidden',
  213. 'std' => '0',
  214. 'type' => 'checkbox'
  215. );
  216. $options[] = array(
  217. 'id' => 'clear'
  218. );

 

二、为新增的筛选条件和筛选结果页布局选项添加显示判断

打开inc/options/includes/themes-options.php文件,大约634~639行的位置,找到代码

  1. jQuery('#filters').click(function() {
  2. jQuery('#section-filters_a_t, #section-filters_b_t, #section-filters_c_t, #section-filters_d_t, #section-filters_e_t, #section-filters_f_t, #section-filter_id, .fi-catid, .fia-catid, #section-filters_img').fadeToggle(400);
  3. });
  4. if (jQuery('#filters:checked').val() !== undefined) {
  5. jQuery('#section-filters_a_t, #section-filters_b_t, #section-filters_c_t, #section-filters_d_t, #section-filters_e_t, #section-filters_f_t, #section-filter_id, .fi-catid, .fia-catid, #section-filters_img').show();
  6. }

将其修改

  1. jQuery('#filters').click(function() {
  2. jQuery('#section-filters_a_t, #section-filters_b_t, #section-filters_c_t, #section-filters_d_t, #section-filters_e_t, #section-filters_f_t, #section-filters_va_t, #section-filters_vb_t, #section-filters_vc_t, #section-filters_vd_t, #section-filters_ve_t, #section-filter_id, .fi-catid, .fia-catid, #section-filters_img, #section-filters_img_v').fadeToggle(400);
  3. });
  4. if (jQuery('#filters:checked').val() !== undefined) {
  5. jQuery('#section-filters_a_t, #section-filters_b_t, #section-filters_c_t, #section-filters_d_t, #section-filters_e_t, #section-filters_f_t, #section-filters_va_t, #section-filters_vb_t, #section-filters_vc_t, #section-filters_vd_t, #section-filters_ve_t, #section-filter_id, .fi-catid, .fia-catid, #section-filters_img, #section-filters_img_v').show();
  6. }

代码作用:

  • 让在“步骤一”中新增的功能可以在后台主题选项中正常显示出来,如下图所示:

为自定义文章类型添加筛选功能

 

三、为新增的筛选功能添加样式,使其与主题原有筛选功能样式保持一致

打开inc/options/css/options.php文件,大约464~468行的位置,找到代码

  1. #section-filters_a, #section-filters_b, #section-filters_c, #section-filters_d, #section-filters_e, #section-filters_f {
  2. float: left;
  3. width: 10px;
  4. margin: 5px 0 0 0;
  5. }

将其替换

  1. #section-filters_a,
  2. #section-filters_b,
  3. #section-filters_c,
  4. #section-filters_d,
  5. #section-filters_e,
  6. #section-filters_f,
  7. #section-filters_va,
  8. #section-filters_vb,
  9. #section-filters_vc,
  10. #section-filters_vd,
  11. #section-filters_ve {
  12. float: left;
  13. width: 10px;
  14. margin: 5px 0 0 0;
  15. }

此时,刷新后台就可以看到样式都正常了,如下图所示:

为自定义文章类型添加筛选功能

 

四、后台“视频”文章编辑页面及左侧“视频”菜单下追加筛选模块

打开inc/filter-tag.php文件,在文件的最后添加代码

  1. if (zm_get_option('filters_va')) {
  2. // 筛选标签VA
  3. add_action( 'init', 'create_filtersva' );
  4. function create_filtersva() {
  5. $labels = array(
  6. 'name' => '筛选VA-类 别',
  7. 'singular_name' => 'filtersva' ,
  8. 'search_items' => '搜索标签',
  9. 'edit_item' => '编辑标签',
  10. 'update_item' => '更新标签',
  11. 'add_new_item' => '添加新标签',
  12. );
  13. register_taxonomy( 'filtersva','video',array(
  14. 'hierarchical' => false,
  15. 'rewrite' => array( 'slug' => $filtersva ),
  16. 'labels' => $labels
  17. ));
  18. }
  19. }
  20. if (zm_get_option('filters_vb')) {
  21. // 筛选标签VB
  22. add_action( 'init', 'create_filtersvb' );
  23. function create_filtersvb() {
  24. $labels = array(
  25. 'name' => '筛选VB-语 言',
  26. 'singular_name' => 'filtersvb' ,
  27. 'search_items' => '搜索标签',
  28. 'edit_item' => '编辑标签',
  29. 'update_item' => '更新标签',
  30. 'add_new_item' => '添加新标签',
  31. );
  32. register_taxonomy( 'filtersvb','video',array(
  33. 'hierarchical' => false,
  34. 'rewrite' => array( 'slug' => $filtersvb ),
  35. 'labels' => $labels
  36. ));
  37. }
  38. }
  39. if (zm_get_option('filters_vc')) {
  40. // 筛选标签VC
  41. add_action( 'init', 'create_filtersvc' );
  42. function create_filtersvc() {
  43. $labels = array(
  44. 'name' => '筛选VC-字 幕',
  45. 'singular_name' => 'filtersvc' ,
  46. 'search_items' => '搜索标签',
  47. 'edit_item' => '编辑标签',
  48. 'update_item' => '更新标签',
  49. 'add_new_item' => '添加新标签',
  50. );
  51. register_taxonomy( 'filtersvc','video',array(
  52. 'hierarchical' => false,
  53. 'rewrite' => array( 'slug' => $filtersvc ),
  54. 'labels' => $labels
  55. ));
  56. }
  57. }
  58. if (zm_get_option('filters_vd')) {
  59. // 筛选标签VD
  60. add_action( 'init', 'create_filtersvd' );
  61. function create_filtersvd() {
  62. $labels = array(
  63. 'name' => '筛选VD-水 印',
  64. 'singular_name' => 'filtersvd' ,
  65. 'search_items' => '搜索标签',
  66. 'edit_item' => '编辑标签',
  67. 'update_item' => '更新标签',
  68. 'add_new_item' => '添加新标签',
  69. );
  70. register_taxonomy( 'filtersvd','video',array(
  71. 'hierarchical' => false,
  72. 'rewrite' => array( 'slug' => $filtersvd ),
  73. 'labels' => $labels
  74. ));
  75. }
  76. }
  77. if (zm_get_option('filters_ve')) {
  78. // 筛选标签VE
  79. add_action( 'init', 'create_filtersve' );
  80. function create_filtersve() {
  81. $labels = array(
  82. 'name' => '筛选VE-清晰度',
  83. 'singular_name' => 'filtersve' ,
  84. 'search_items' => '搜索标签',
  85. 'edit_item' => '编辑标签',
  86. 'update_item' => '更新标签',
  87. 'add_new_item' => '添加新标签',
  88. );
  89. register_taxonomy( 'filtersve','video',array(
  90. 'hierarchical' => false,
  91. 'rewrite' => array( 'slug' => $filtersve ),
  92. 'labels' => $labels
  93. ));
  94. }
  95. }

代码说明:

  • 代码中的video是我的自定义文章类型:视频的别名,请修改成你自己的自定义文章类型别名,因为添加了五个筛选条件,对应的就有五个筛选模块,所以共有五个video需要修改。

完成“步骤四”操作后就可以在后台“视频”文章编辑页面和左侧“视频”菜单下看到新增的这五个筛选模块了,如下图所示:

为自定义文章类型添加筛选功能

Ps:如果你看不到这些模块的话,需要在右上角的显示选项勾选这些模块。

 

第二部分:前台相关功能的实现

五、头部文件添加判断

打开template/header-sub.php文件,大约25行的位置,找到代码

  1. <?php if (in_category(explode(',',zm_get_option('filter_id') ) ) && !is_single() && !is_home() && !is_author() && !is_search()) { ?>

将其替换

  1. <?php if ((in_category(explode(',',zm_get_option('filter_id') ) ) || get_post_type()=='video' ) && !is_single() && !is_home() && !is_author() && !is_search()) { ?>

代码作用:

  • 增加一个是否是自定义文章类型:视频(video)的判断,以使下面将要添加在前台显示的五个筛选条件可以在前台正常输出

 

六、添加前台筛选功能并做文章类型判断

首先:打开inc/filter.php文件,找到第5行代码

  1. <div class="filter-box-main">

在其下面添加

  1. <?php if (in_category(explode(',',zm_get_option('filter_id') ) ) && !is_single() && !is_home() && !is_author() && !is_search()) { ?>

代码作用:

  • 用来判断原有的筛选条件是否只在内置文章类型中才显示,与下面将要新增的五个筛选条件做区分

然后:在同文件最后三行代码

  1. <div class="clear"></div>
  2. </div>
  3. </div>

上面添加

  1. <?php } ?>
  2. <?php if(get_post_type()=='video') {?>
  3. <?php if (zm_get_option('filters_va')) { ?>
  4. <div class="clear"></div>
  5. <div class="filter-main">
  6. <span class="filter-name"><i class="be be-sort"></i><?php echo zm_get_option('filters_va_t'); ?></span>
  7. <span class="filtertag" id="filtersva"<?php if($filtersva!=''){echo ' data="'.strtolower(urlencode(urldecode(urldecode($filtersva)))).'"';}?>>
  8. <?php
  9. $terms = get_terms("filtersva");
  10. $countcount = count($terms);
  11. if ( $count > 0 ){
  12. foreach ( $terms as $term ) {
  13. if(strtolower(urlencode(urldecode(urldecode($filtersva))))==$term->slug){
  14. echo '<a class="filter-tag filter-on" data="'. $term->slug .'">' . $term->name . '</a>';
  15. }else{
  16. echo '<a class="filter-tag" data="'. $term->slug .'">' . $term->name . '</a>';
  17. }
  18. }
  19. }
  20. ?>
  21. </span>
  22. </div>
  23. <?php } ?>
  24. <?php if (zm_get_option('filters_vb')) { ?>
  25. <div class="clear"></div>
  26. <div class="filter-main">
  27. <span class="filter-name"><i class="be be-sort"></i><?php echo zm_get_option('filters_vb_t'); ?></span>
  28. <span class="filtertag" id="filtersvb"<?php if($filtersvb!=''){echo ' data="'.strtolower(urlencode(urldecode(urldecode($filtersvb)))).'"';}?>>
  29. <?php
  30. $terms = get_terms("filtersvb");
  31. $countcount = count($terms);
  32. if ( $count > 0 ){
  33. foreach ( $terms as $term ) {
  34. if(strtolower(urlencode(urldecode(urldecode($filtersvb))))==$term->slug){
  35. echo '<a class="filter-tag filter-on" data="'. $term->slug .'">' . $term->name . '</a>';
  36. }else{
  37. echo '<a class="filter-tag" data="'. $term->slug .'">' . $term->name . '</a>';
  38. }
  39. }
  40. }
  41. ?>
  42. </span>
  43. </div>
  44. <?php } ?>
  45. <?php if (zm_get_option('filters_vc')) { ?>
  46. <div class="clear"></div>
  47. <div class="filter-main">
  48. <span class="filter-name"><i class="be be-sort"></i><?php echo zm_get_option('filters_vc_t'); ?></span>
  49. <span class="filtertag" id="filtersvc"<?php if($filtersvc!=''){echo ' data="'.strtolower(urlencode(urldecode(urldecode($filtersvc)))).'"';}?>>
  50. <?php
  51. $terms = get_terms("filtersvc");
  52. $countcount = count($terms);
  53. if ( $count > 0 ){
  54. foreach ( $terms as $term ) {
  55. if(strtolower(urlencode(urldecode(urldecode($filtersvc))))==$term->slug){
  56. echo '<a class="filter-tag filter-on" data="'. $term->slug .'">' . $term->name . '</a>';
  57. }else{
  58. echo '<a class="filter-tag" data="'. $term->slug .'">' . $term->name . '</a>';
  59. }
  60. }
  61. }
  62. ?>
  63. </span>
  64. </div>
  65. <?php } ?>
  66. <?php if (zm_get_option('filters_vd')) { ?>
  67. <div class="clear"></div>
  68. <div class="filter-main">
  69. <span class="filter-name"><i class="be be-sort"></i><?php echo zm_get_option('filters_vd_t'); ?></span>
  70. <span class="filtertag" id="filtersvd"<?php if($filtersvd!=''){echo ' data="'.strtolower(urlencode(urldecode(urldecode($filtersvd)))).'"';}?>>
  71. <?php
  72. $terms = get_terms("filtersvd");
  73. $countcount = count($terms);
  74. if ( $count > 0 ){
  75. foreach ( $terms as $term ) {
  76. if(strtolower(urlencode(urldecode(urldecode($filtersvd))))==$term->slug){
  77. echo '<a class="filter-tag filter-on" data="'. $term->slug .'">' . $term->name . '</a>';
  78. }else{
  79. echo '<a class="filter-tag" data="'. $term->slug .'">' . $term->name . '</a>';
  80. }
  81. }
  82. }
  83. ?>
  84. </span>
  85. </div>
  86. <?php } ?>
  87. <?php if (zm_get_option('filters_ve')) { ?>
  88. <div class="clear"></div>
  89. <div class="filter-main">
  90. <span class="filter-name"><i class="be be-sort"></i><?php echo zm_get_option('filters_ve_t'); ?></span>
  91. <span class="filtertag" id="filtersve"<?php if($filtersve!=''){echo ' data="'.strtolower(urlencode(urldecode(urldecode($filtersve)))).'"';}?>>
  92. <?php
  93. $terms = get_terms("filtersve");
  94. $countcount = count($terms);
  95. if ( $count > 0 ){
  96. foreach ( $terms as $term ) {
  97. if(strtolower(urlencode(urldecode(urldecode($filtersve))))==$term->slug){
  98. echo '<a class="filter-tag filter-on" data="'. $term->slug .'">' . $term->name . '</a>';
  99. }else{
  100. echo '<a class="filter-tag" data="'. $term->slug .'">' . $term->name . '</a>';
  101. }
  102. }
  103. }
  104. ?>
  105. </span>
  106. </div>
  107. <?php } ?>
  108. <?php }?>

代码说明:

  • 第1行:用来结束上一步操作中的第5行的判断
  • 第3行:用来判断新增的五个筛选条件是否只在自定义文章类型:视频(video)下才输出
  • 第4~112行:用来输出新增的五个筛选条件
  • 第113行:用来结束第3行的判断

完成“步骤五”、“步骤六”的操作后,这个文件的完整代码如下:展开

  1. <div class="filter-box">
  2. <div class="filter-box-title">
  3. <span></span>
  4. </div>
  5. <div class="filter-box-main">
  6. <?php if (in_category(explode(',',zm_get_option('filter_id') ) ) && !is_single() && !is_home() && !is_author() && !is_search()) { ?>
  7. <?php if (zm_get_option('filters_a')) { ?>
  8. <div class="filter-main">
  9. <span class="filter-name"><i class="be be-sort"></i><?php echo zm_get_option('filters_a_t'); ?></span>
  10. <span class="filtertag" id="filtersa"<?php if($filtersa!=''){echo ' data="'.strtolower(urlencode(urldecode(urldecode($filtersa)))).'"';}?>>
  11. <?php
  12. $terms = get_terms("filtersa");
  13. $countcount = count($terms);
  14. if ( $count > 0 ){
  15. foreach ( $terms as $term ) {
  16. if(strtolower(urlencode(urldecode(urldecode($filtersa))))==$term->slug){
  17. echo '<a class="filter-tag filter-on" data="'. $term->slug .'">' . $term->name . '</a>';
  18. }else{
  19. echo '<a class="filter-tag" data="'. $term->slug .'">' . $term->name . '</a>';
  20. }
  21. }
  22. }
  23. ?>
  24. </span>
  25. </div>
  26. <?php } ?>
  27. <?php if (zm_get_option('filters_b')) { ?>
  28. <div class="clear"></div>
  29. <div class="filter-main">
  30. <span class="filter-name"><i class="be be-sort"></i><?php echo zm_get_option('filters_b_t'); ?></span>
  31. <span class="filtertag" id="filtersb"<?php if($filtersb!=''){echo ' data="'.strtolower(urlencode(urldecode(urldecode($filtersb)))).'"';}?>>
  32. <?php
  33. $terms = get_terms("filtersb");
  34. $countcount = count($terms);
  35. if ( $count > 0 ){
  36. foreach ( $terms as $term ) {
  37. if(strtolower(urlencode(urldecode(urldecode($filtersb))))==$term->slug){
  38. echo '<a class="filter-tag filter-on" data="'. $term->slug .'">' . $term->name . '</a>';
  39. }else{
  40. echo '<a class="filter-tag" data="'. $term->slug .'">' . $term->name . '</a>';
  41. }
  42. }
  43. }
  44. ?>
  45. </span>
  46. </div>
  47. <?php } ?>
  48. <?php if (zm_get_option('filters_c')) { ?>
  49. <div class="clear"></div>
  50. <div class="filter-main">
  51. <span class="filter-name"><i class="be be-sort"></i><?php echo zm_get_option('filters_c_t'); ?></span>
  52. <span class="filtertag" id="filtersc"<?php if($filtersc!=''){echo ' data="'.strtolower(urlencode(urldecode(urldecode($filtersc)))).'"';}?>>
  53. <?php
  54. $terms = get_terms("filtersc");
  55. $countcount = count($terms);
  56. if ( $count > 0 ){
  57. foreach ( $terms as $term ) {
  58. if(strtolower(urlencode(urldecode(urldecode($filtersc))))==$term->slug){
  59. echo '<a class="filter-tag filter-on" data="'. $term->slug .'">' . $term->name . '</a>';
  60. }else{
  61. echo '<a class="filter-tag" data="'. $term->slug .'">' . $term->name . '</a>';
  62. }
  63. }
  64. }
  65. ?>
  66. </span>
  67. </div>
  68. <?php } ?>
  69. <?php if (zm_get_option('filters_d')) { ?>
  70. <div class="clear"></div>
  71. <div class="filter-main">
  72. <span class="filter-name"><i class="be be-sort"></i><?php echo zm_get_option('filters_d_t'); ?></span>
  73. <span class="filtertag" id="filtersd"<?php if($filtersd!=''){echo ' data="'.strtolower(urlencode(urldecode(urldecode($filtersd)))).'"';}?>>
  74. <?php
  75. $terms = get_terms("filtersd");
  76. $countcount = count($terms);
  77. if ( $count > 0 ){
  78. foreach ( $terms as $term ) {
  79. if(strtolower(urlencode(urldecode(urldecode($filtersd))))==$term->slug){
  80. echo '<a class="filter-tag filter-on" data="'. $term->slug .'">' . $term->name . '</a>';
  81. }else{
  82. echo '<a class="filter-tag" data="'. $term->slug .'">' . $term->name . '</a>';
  83. }
  84. }
  85. }
  86. ?>
  87. </span>
  88. </div>
  89. <?php } ?>
  90. <?php if (zm_get_option('filters_e')) { ?>
  91. <div class="clear"></div>
  92. <div class="filter-main">
  93. <span class="filter-name"><i class="be be-sort"></i><?php echo zm_get_option('filters_e_t'); ?></span>
  94. <span class="filtertag" id="filterse"<?php if($filterse!=''){echo ' data="'.strtolower(urlencode(urldecode(urldecode($filterse)))).'"';}?>>
  95. <?php
  96. $terms = get_terms("filterse");
  97. $countcount = count($terms);
  98. if ( $count > 0 ){
  99. foreach ( $terms as $term ) {
  100. if(strtolower(urlencode(urldecode(urldecode($filterse))))==$term->slug){
  101. echo '<a class="filter-tag filter-on" data="'. $term->slug .'">' . $term->name . '</a>';
  102. }else{
  103. echo '<a class="filter-tag" data="'. $term->slug .'">' . $term->name . '</a>';
  104. }
  105. }
  106. }
  107. ?>
  108. </span>
  109. </div>
  110. <?php } ?>
  111. <?php if (zm_get_option('filters_f')) { ?>
  112. <div class="clear"></div>
  113. <div class="filter-main">
  114. <span class="filter-name"><i class="be be-sort"></i><?php echo zm_get_option('filters_f_t'); ?></span>
  115. <span class="filtertag" id="filtersf"<?php if($filtersf!=''){echo ' data="'.strtolower(urlencode(urldecode(urldecode($filtersf)))).'"';}?>>
  116. <?php
  117. $terms = get_terms("filtersf");
  118. $countcount = count($terms);
  119. if ( $count > 0 ){
  120. foreach ( $terms as $term ) {
  121. if(strtolower(urlencode(urldecode(urldecode($filtersf))))==$term->slug){
  122. echo '<a class="filter-tag filter-on" data="'. $term->slug .'">' . $term->name . '</a>';
  123. }else{
  124. echo '<a class="filter-tag" data="'. $term->slug .'">' . $term->name . '</a>';
  125. }
  126. }
  127. }
  128. ?>
  129. </span>
  130. </div>
  131. <?php } ?>
  132. <?php } ?>
  133. <?php if(get_post_type()=='video') {?>
  134. <?php if (zm_get_option('filters_va')) { ?>
  135. <div class="clear"></div>
  136. <div class="filter-main">
  137. <span class="filter-name"><i class="be be-sort"></i><?php echo zm_get_option('filters_va_t'); ?></span>
  138. <span class="filtertag" id="filtersva"<?php if($filtersva!=''){echo ' data="'.strtolower(urlencode(urldecode(urldecode($filtersva)))).'"';}?>>
  139. <?php
  140. $terms = get_terms("filtersva");
  141. $countcount = count($terms);
  142. if ( $count > 0 ){
  143. foreach ( $terms as $term ) {
  144. if(strtolower(urlencode(urldecode(urldecode($filtersva))))==$term->slug){
  145. echo '<a class="filter-tag filter-on" data="'. $term->slug .'">' . $term->name . '</a>';
  146. }else{
  147. echo '<a class="filter-tag" data="'. $term->slug .'">' . $term->name . '</a>';
  148. }
  149. }
  150. }
  151. ?>
  152. </span>
  153. </div>
  154. <?php } ?>
  155. <?php if (zm_get_option('filters_vb')) { ?>
  156. <div class="clear"></div>
  157. <div class="filter-main">
  158. <span class="filter-name"><i class="be be-sort"></i><?php echo zm_get_option('filters_vb_t'); ?></span>
  159. <span class="filtertag" id="filtersvb"<?php if($filtersvb!=''){echo ' data="'.strtolower(urlencode(urldecode(urldecode($filtersvb)))).'"';}?>>
  160. <?php
  161. $terms = get_terms("filtersvb");
  162. $countcount = count($terms);
  163. if ( $count > 0 ){
  164. foreach ( $terms as $term ) {
  165. if(strtolower(urlencode(urldecode(urldecode($filtersvb))))==$term->slug){
  166. echo '<a class="filter-tag filter-on" data="'. $term->slug .'">' . $term->name . '</a>';
  167. }else{
  168. echo '<a class="filter-tag" data="'. $term->slug .'">' . $term->name . '</a>';
  169. }
  170. }
  171. }
  172. ?>
  173. </span>
  174. </div>
  175. <?php } ?>
  176. <?php if (zm_get_option('filters_vc')) { ?>
  177. <div class="clear"></div>
  178. <div class="filter-main">
  179. <span class="filter-name"><i class="be be-sort"></i><?php echo zm_get_option('filters_vc_t'); ?></span>
  180. <span class="filtertag" id="filtersvc"<?php if($filtersvc!=''){echo ' data="'.strtolower(urlencode(urldecode(urldecode($filtersvc)))).'"';}?>>
  181. <?php
  182. $terms = get_terms("filtersvc");
  183. $countcount = count($terms);
  184. if ( $count > 0 ){
  185. foreach ( $terms as $term ) {
  186. if(strtolower(urlencode(urldecode(urldecode($filtersvc))))==$term->slug){
  187. echo '<a class="filter-tag filter-on" data="'. $term->slug .'">' . $term->name . '</a>';
  188. }else{
  189. echo '<a class="filter-tag" data="'. $term->slug .'">' . $term->name . '</a>';
  190. }
  191. }
  192. }
  193. ?>
  194. </span>
  195. </div>
  196. <?php } ?>
  197. <?php if (zm_get_option('filters_vd')) { ?>
  198. <div class="clear"></div>
  199. <div class="filter-main">
  200. <span class="filter-name"><i class="be be-sort"></i><?php echo zm_get_option('filters_vd_t'); ?></span>
  201. <span class="filtertag" id="filtersvd"<?php if($filtersvd!=''){echo ' data="'.strtolower(urlencode(urldecode(urldecode($filtersvd)))).'"';}?>>
  202. <?php
  203. $terms = get_terms("filtersvd");
  204. $countcount = count($terms);
  205. if ( $count > 0 ){
  206. foreach ( $terms as $term ) {
  207. if(strtolower(urlencode(urldecode(urldecode($filtersvd))))==$term->slug){
  208. echo '<a class="filter-tag filter-on" data="'. $term->slug .'">' . $term->name . '</a>';
  209. }else{
  210. echo '<a class="filter-tag" data="'. $term->slug .'">' . $term->name . '</a>';
  211. }
  212. }
  213. }
  214. ?>
  215. </span>
  216. </div>
  217. <?php } ?>
  218. <?php if (zm_get_option('filters_ve')) { ?>
  219. <div class="clear"></div>
  220. <div class="filter-main">
  221. <span class="filter-name"><i class="be be-sort"></i><?php echo zm_get_option('filters_ve_t'); ?></span>
  222. <span class="filtertag" id="filtersve"<?php if($filtersve!=''){echo ' data="'.strtolower(urlencode(urldecode(urldecode($filtersve)))).'"';}?>>
  223. <?php
  224. $terms = get_terms("filtersve");
  225. $countcount = count($terms);
  226. if ( $count > 0 ){
  227. foreach ( $terms as $term ) {
  228. if(strtolower(urlencode(urldecode(urldecode($filtersve))))==$term->slug){
  229. echo '<a class="filter-tag filter-on" data="'. $term->slug .'">' . $term->name . '</a>';
  230. }else{
  231. echo '<a class="filter-tag" data="'. $term->slug .'">' . $term->name . '</a>';
  232. }
  233. }
  234. }
  235. ?>
  236. </span>
  237. </div>
  238. <?php } ?>
  239. <?php }?>
  240. <div class="clear"></div>
  241. </div>
  242. </div>

 

七、添加地址栏参数传递

首先:打开js/script.php文件,大约380~386行的位置,找到代码

  1. var url = urlNow;
  2. var filtersa = $('#filtersa').attr('data');
  3. var filtersb = $('#filtersb').attr('data');
  4. var filtersc = $('#filtersc').attr('data');
  5. var filtersd = $('#filtersd').attr('data');
  6. var filterse = $('#filterse').attr('data');
  7. var filtersf = $('#filtersf').attr('data');

在其下面添加

  1. var filtersva = $('#filtersva').attr('data');
  2. var filtersvb = $('#filtersvb').attr('data');
  3. var filtersvc = $('#filtersvc').attr('data');
  4. var filtersvd = $('#filtersvd').attr('data');
  5. var filtersve = $('#filtersve').attr('data');

然后:再往下的位置找到代码

  1. if (urlNow != url) {
  2. window.location.href = url;
  3. }
  4. )

在其上面添加

  1. if (typeof(filtersva) != 'undefined') {
  2. if (url.substr( - 1) != '?') {
  3. url += '&';
  4. }
  5. if (filtersva.length > 0) {
  6. url += 'filtersva=' + filtersva;
  7. }
  8. }
  9. if (typeof(filtersvb) != 'undefined') {
  10. if (url.substr( - 1) != '?') {
  11. url += '&';
  12. }
  13. if (filtersvb.length > 0) {
  14. url += 'filtersvb=' + filtersvb;
  15. }
  16. }
  17. if (typeof(filtersvc) != 'undefined') {
  18. if (url.substr( - 1) != '?') {
  19. url += '&';
  20. }
  21. if (filtersvc.length > 0) {
  22. url += 'filtersvc=' + filtersvc;
  23. }
  24. }
  25. if (typeof(filtersvd) != 'undefined') {
  26. if (url.substr( - 1) != '?') {
  27. url += '&';
  28. }
  29. if (filtersvd.length > 0) {
  30. url += 'filtersvd=' + filtersvd;
  31. }
  32. }
  33. if (typeof(filtersve) != 'undefined') {
  34. if (url.substr( - 1) != '?') {
  35. url += '&';
  36. }
  37. if (filtersve.length > 0) {
  38. url += 'filtersve=' + filtersve;
  39. }
  40. }

重要说明:如果你在完成这一步操作(包括后面要讲的操作)后去测试时发现:当你点击筛选条件中的任何一个筛选标签(包括添加在主题原有的筛选条件中的筛选标签)时,页面无论如何都不会跳转到筛选结果页或筛选结果页显示404错误时,你需要将用来获取URL地址部分的代码(位于这个文件筛选部分)稍做调整,具体如下:

在这个文件中,大约370~378行的位置,找到代码

  1. if(ishttps){
  2. var urlNow = 'https://' + window.location.host + '/?';
  3. }else{
  4. if (window.location.host=="127.0.0.1" || window.location.host=="localhost" ){
  5. var urlNow = 'http://' + window.location.host + '/wordpress/?';
  6. }else{
  7. var urlNow = 'http://' + window.location.host + '/?';
  8. }
  9. }

修改

  1. if(ishttps){
  2. var urlNow = 'https://' + window.location.host + '/?';
  3. }else{
  4. // if (window.location.host=="127.0.0.1" || window.location.host=="localhost" ){
  5. // var urlNow = 'http://' + window.location.host + '/wordpress/?';
  6. // }else{
  7. var urlNow = 'http://' + window.location.host + '/?';
  8. // }
  9. }

也就是将这段代码中的第4~6行和第8行代码注释或删除掉。

为了便于理解,在此附上这个文件中关于筛选部分的完整代码展开

  1. // filters
  2. $(".filter-box-title").click(function() {
  3. $ (this).toggleClass ("off-filter-box-title");
  4. $ (this).toggleClass ("off-filter-box-main");
  5. $ (".filter-box-main").toggleClass ("filter-box-main-display");
  6. });
  7. $('.filtertag a').click(function() {
  8. var papaDate = $(this).parent('.filtertag').attr('data');
  9. $(this).parent('.filtertag').find('a').css('borderColor', '');
  10. if (papaDate == undefined | papaDate == "" | papaDate != $(this).attr('data')) {
  11. $(this).css('borderColor', '#ddd').parent('.filtertag').attr('data', $(this).attr('data'));
  12. } else if (papaDate == $(this).attr('data')) {
  13. $(this).css('borderColor', '').parent('.filtertag').attr('data', '');
  14. } else {
  15. $(this).css('borderColor', '').parent('.filtertag').attr('data', '');
  16. }
  17. var ishttps = 'https:' == document.location.protocol ? true: false;
  18. if(ishttps){
  19. var urlNow = 'https://' + window.location.host + '/?';
  20. }else{
  21. // if (window.location.host=="127.0.0.1" || window.location.host=="localhost" ){
  22. // var urlNow = 'http://' + window.location.host + '/wordpress/?';
  23. // }else{
  24. var urlNow = 'http://' + window.location.host + '/?';
  25. // }
  26. }
  27. var url = urlNow;
  28. var filtersa = $('#filtersa').attr('data');
  29. var filtersb = $('#filtersb').attr('data');
  30. var filtersc = $('#filtersc').attr('data');
  31. var filtersd = $('#filtersd').attr('data');
  32. var filterse = $('#filterse').attr('data');
  33. var filtersf = $('#filtersf').attr('data');
  34. var filtersva = $('#filtersva').attr('data');
  35. var filtersvb = $('#filtersvb').attr('data');
  36. var filtersvc = $('#filtersvc').attr('data');
  37. var filtersvd = $('#filtersvd').attr('data');
  38. var filtersve = $('#filtersve').attr('data');
  39. if (typeof(filtersa) != 'undefined') {
  40. if (filtersa.length > 0) {
  41. url += 'filtersa=' + filtersa;
  42. }
  43. }
  44. if (typeof(filtersb) != 'undefined') {
  45. if (url.substr( - 1) != '?') {
  46. url += '&';
  47. }
  48. if (filtersb.length > 0) {
  49. url += 'filtersb=' + filtersb;
  50. }
  51. }
  52. if (typeof(filtersc) != 'undefined') {
  53. if (url.substr( - 1) != '?') {
  54. url += '&';
  55. }
  56. if (filtersc.length > 0) {
  57. url += 'filtersc=' + filtersc;
  58. }
  59. }
  60. if (typeof(filtersd) != 'undefined') {
  61. if (url.substr( - 1) != '?') {
  62. url += '&';
  63. }
  64. if (filtersd.length > 0) {
  65. url += 'filtersd=' + filtersd;
  66. }
  67. }
  68. if (typeof(filterse) != 'undefined') {
  69. if (url.substr( - 1) != '?') {
  70. url += '&';
  71. }
  72. if (filterse.length > 0) {
  73. url += 'filterse=' + filterse;
  74. }
  75. }
  76. if (typeof(filtersf) != 'undefined') {
  77. if (url.substr( - 1) != '?') {
  78. url += '&';
  79. }
  80. if (filtersf.length > 0) {
  81. url += 'filtersf=' + filtersf;
  82. }
  83. }
  84. if (typeof(filtersva) != 'undefined') {
  85. if (url.substr( - 1) != '?') {
  86. url += '&';
  87. }
  88. if (filtersva.length > 0) {
  89. url += 'filtersva=' + filtersva;
  90. }
  91. }
  92. if (typeof(filtersvb) != 'undefined') {
  93. if (url.substr( - 1) != '?') {
  94. url += '&';
  95. }
  96. if (filtersvb.length > 0) {
  97. url += 'filtersvb=' + filtersvb;
  98. }
  99. }
  100. if (typeof(filtersvc) != 'undefined') {
  101. if (url.substr( - 1) != '?') {
  102. url += '&';
  103. }
  104. if (filtersvc.length > 0) {
  105. url += 'filtersvc=' + filtersvc;
  106. }
  107. }
  108. if (typeof(filtersvd) != 'undefined') {
  109. if (url.substr( - 1) != '?') {
  110. url += '&';
  111. }
  112. if (filtersvd.length > 0) {
  113. url += 'filtersvd=' + filtersvd;
  114. }
  115. }
  116. if (typeof(filtersve) != 'undefined') {
  117. if (url.substr( - 1) != '?') {
  118. url += '&';
  119. }
  120. if (filtersve.length > 0) {
  121. url += 'filtersve=' + filtersve;
  122. }
  123. }
  124. if (urlNow != url) {
  125. window.location.href = url;
  126. }
  127. })

 

八、导航栏中追加“筛选结果”

打开inc/inc.php文件,大约408行的位置,找到代码

  1. if ( is_tax('filtersa') || is_tax('filtersb') || is_tax('filtersc') || is_tax('filtersd') || is_tax('filterse') || is_tax('filtersf') ) {
  2. echo '<i class="be be-arrowright"></i>筛选结果';
  3. }

将其修改

  1. if ( is_tax('filtersa') || is_tax('filtersb') || is_tax('filtersc') || is_tax('filtersd') || is_tax('filterse') || is_tax('filtersf')|| is_tax('filtersva')|| is_tax('filtersvb')|| is_tax('filtersvc')|| is_tax('filtersvd')|| is_tax('filtersve') ) {
  2. echo '<i class="be be-arrowright"></i>筛选结果';
  3. }

完成“第八步”操作后,当你点击筛选标签时就可以在筛选结果页的导航中看到效果了,如下图所示:

为自定义文章类型添加筛选功能

 

九、添加筛选结果页布局判断

打开taxonomy.php文件,大约41行的位置,找到代码

  1. <?php if (zm_get_option('filters_img')) { ?>

将其替换

  1. <?php if (zm_get_option('filters_img_v') && (get_post_type()=='video') || zm_get_option('filters_img') && (get_post_type()!=='video')) { ?>

代码作用:

  • 通过在taxonomy.php文件中添加文章类型判断,并结合下面的代码来实现“不同文章类型下的筛选结果页使用不同布局”的目的。

 

十、调整“图片布局 ”中缩略图调用函数

  • 主题缩略图函数调用原理

主题本身集成了多种缩略图显示方式,这些缩略图的尺寸是可以自定义的,具体可以在后台--外观--主题选项--基本设置--缩略图自动裁剪设置中查看。

而这些缩略图所调用的函数体也是不同的。比如“标准缩略图”调用的是“标准缩略图”函数体,“视频缩略图”调用的是“视频缩略图”函数体,“图片布局”调用的是“图片布局缩略图”函数体,等等。而在这些函数体内部,他们的执行过程一般是这样的:

首先判断文章编辑页面(含自定义文章类型下的文章编辑页面)是否设置了自定义缩略图地址,如果设置了这个地址则使用这个地址(图片)作为缩略图显示;如果没有设置,则获取正文中的第一张图片作为缩略图显示;如果正文中没有图片,则获取特色图像作为缩略图显示(如果你在后台主题选项中启用了特色图像功能的话);如果特色图像中也没有设置,则调用随机缩略图(主题img/random/目录下的图片)作为缩略图显示。

  • 调整函数调用原因

第一个原因:查看多条件筛选功能中的筛选结果使用图片布局选项所对应的代码发现,他调用的是“标准缩略图”函数体,并没有调用“图片布局缩略图”函数体。

第二个原因:即使调用了“图片布局缩略图”函数体,也无法获取自定义文章类型中的自定义缩略图地址作为缩略图显示在筛选结果页(即使你在自定义文章类型下的文章中设置了自定义缩略图)。因为自定义文章类型:视频中的自定义缩略图地址只被“视频缩略图”函数体调用,因此在“图片布局缩略图”函数体内部,由于他获取不到自定义文章类型中的自定义缩略图地址,他就只能依次获取正文中的图片、特色图像,如果都没有,就直接调用“随机缩略图”函数了。

第三个原因:对于自定义文章类型:视频中的视频文章,一般情况下我都会设置自定义缩略图作为缩略图显示在视频分类下,而视频文章正文中很少单独添加图片。

由于以上三个原因的存在,造成了默认情况下当我在后台多条件筛选功能中启用

为自定义文章类型添加筛选功能

这两个功能时,前台筛选结果页的缩略图显示会出现问题,具体表现在两个地方:

  • 第一个地方:当两个选项都不启用

此时,内置文章类型下的筛选结果页显示为

为自定义文章类型添加筛选功能

这样的显示是正常的,但是在自定义文章类型:视频下的筛选结果页显示为

为自定义文章类型添加筛选功能

可以明显看到,自定义文章类型:视频下的筛选结果页缩略图显示是有问题的,他显示的是随机缩略图而不是我在视频文章中设置的自定义图片。至于样式问题(排版和列表背景)是主题本身代码不够完善造成的,至于怎么修正暂且不管(后面会提到)。

顺便提一下的是:当筛选结果页使用图片布局选项不启用时,筛选结果页则以默认的“列表布局”方式显示筛选结果。

  • 第二个地方:仅启用第二个选项

此时,自定义文章类型:视频下的筛选结果页显示为

为自定义文章类型添加筛选功能

同样的,是由于他无法获取自定义文章类型中的自定义缩略图地址造成的。

  • 解决思路

由于自定义文章类型:视频下的分类默认就是图片布局的,而“视频缩略图”函数体又可以获取视频文章中自定义的缩略图地址,因此通过添加判断,让自定义文章类型:视频的筛选结果页调用“视频缩略图”函数体,从而让自定义文章类型:视频的筛选结果页使用“图片布局”时可以正常显示想要的图片。

所以,假如你的自定义文章类型中设置了自定义缩略图地址,而你又希望“筛选结果页”调用这个地址的话,你就需要和我一样修改相关的代码,具体看下面操作。

  • 调整函数调用操作方法

打开taxonomy.php文件,大约53行的位置,找到代码

  1. <?php if (zm_get_option('lazy_s')) { zm_thumbnail_h(); } else { zm_thumbnail(); } ?>

将其替换

  1. <?php
  2. if (zm_get_option('lazy_s') && get_post_type()=='video') { videos_thumbnail_h(); }
  3. elseif (zm_get_option('lazy_s')) { zm_thumbnail_h(); }
  4. else {zm_thumbnail();}
  5. ?>

修改后,就可以看到图片显示都正常了,如下图所示:

为自定义文章类型添加筛选功能

需要注意的几个地方:

  • 使用修改后的代码,你需要为视频文章设置自定义的缩略图地址,或让你想要显示在筛选结果页中的图片出现在正文或特色图像中,否则他会显示随机缩略图
  • 建议内置文章类型不勾选“筛选结果页使用图片布局”选项,自定义文章类型:视频勾选“筛选结果页使用图片布局”选项,这样可以促使博客结构更加多样化
  • 如果自定义文章类型:视频不勾选“筛选结果页使用图片布局”选项的话,会造成筛选结果页样式出现问题(就是前面看到的那个效果)
  • 如果你坚持自定义文章类型:视频不勾选“筛选结果页使用图片布局”选项的话,你需要修改style.css文件中相关的样式。我觉得没这个必要所以没有进一步修改,如果你觉得有这个需要,那还需要你自己慢慢修改了,但我个人还是不建议这么操作

 

文章总结

  • 总体来说,为自定义文章类型添加筛选功能只是操作步骤和涉及的文件较多,从操作的难易程度上来说也不算太难,操作时细心点,变量名什么的替换完整了应该不会有什么问题。
  • 主要就是最后的筛选结果页布局问题,由于涉及到了不同缩略图函数体的调用,以及函数体中的执行过程,使得“步骤十”看上去略显复杂。
  • 我是个基本不懂代码的小白,所以花了不少时间在这里,而且也没能进一步完善这部分的功能,相信各位童鞋的能力一定是在我之上的,对你们来说这些应该也是轻而易举的事情。

对于整篇文章,需要注意的地方:

  1. 由于添加的“筛选条件”较多,涉及的文件也较多,因此当你修改了“筛选条件”中的id时,你要确保这个id所对应的每个地方都正确修改了
  2. 在后台新增筛选条件并启用后,需要在后台--设置--固定链接中重新点一次保存更改按钮,不然前台可能无法正常显示
  3. 当你完成整个操作,并在前台测试筛选功能时,发现筛选结果页总是提示404错误,你需要参考“步骤七”中的“重要说明”
  4. 其他文中提到需要注意的地方

最后,感谢大家的阅读!

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

目前评论:1   其中:访客  1   博主  0

    • avatar 免费SSR节点 1

      不错的文章!