该插件尚未通过WordPress的最新3个主要版本进行测试。 当与较新版本的WordPress一起使用时,可能不再受到维护或支持,并且可能会存在兼容性问题。

Custom Taxonomy Sort

描述

Surprisingly, WordPress does not provide a mechanism for sorting taxonomies by a custom defined order. Taxonomies can only be sorted by name or id. Custom Taxonomy Sort allows the average user a mechanism to define and display terms in a specified order. After installing Custom Taxonomy Sort, each taxonomy term will have the ability to have a “tax-order” value associated with it. This order is specified by doing the following:

  1. Go to any taxonomy add or edit screen (e.g., wp-admin/edit-tags.php?taxonomy=category)
  2. Fill in a numeric value for the “Order” field. By default, the order will be ascending, meaning it will sort from low to high (e.g., 1, 2, 3). These values can be added on the Add Taxonomy screen, the Edit Taxonomy screen, or through the Quick Edit panel.
  3. Observe all of your terms automagically being sorted in the order you specified

Custom Taxonomy Sort automatically applies the sort order to all instances in which the terms are displayed. All you need to do is define that order.

Manual Mode

In addition to automatically sorting the terms, Custom Taxonomy Sort allows developers to override the automatic sort to offer finer control over how terms are displayed in different parts of WordPress. Manual mode can be started by changing “Automatic Sort” to “Off” in the Custom Taxonomy Sort Settings page (wp-admin/options-general.php?page=custom-taxonomy-sort-settings). Once “Automatic Sort” is switched to “Off”, the terms will no longer be sorted automatically by the custom order. Instead, the custom sort order can be envoked with a new parameter for the “orderby” argument. Custom Taxonomy Sort allows you to use the following argument to access a custom sorted list of terms using “get_terms”

<?php get_terms('orderby=custom_sort'); ?>

Voila! Now, your terms will only be sorted by the specified order in the places that you want it sorted in this order. All other instances of displaying terms will revert to WordPress’ default of sorting the terms by name. Additionally, you can specifically have the terms sort in ascending (‘ASC’; default; e.g., 1, 2, 3) or descending (‘DESC’; e.g., 3, 2, 1) order by adding the “order” argument.

<?php get_terms('orderby=custom_sort&order=ASC'); ?>

<?php get_terms('orderby=custom_sort&order=DESC'); ?>

Acknowledgements

  • Thanks to Jacob M Goldman for his excellent Simple Term Meta plugin, which made programming the term meta quite simple.
  • Thanks to hydrowire for pointing out a bug fixed in 1.1.1
  • Thanks to “Mosey” for pointing out a bug with a situation in which order did not work for a custom taxonomy
  • Thanks to DUCK__BOY1981 for pointing out a bug where the column values where overridden inappropriately
  • Thanks to @martindj for pointing out a bug where the column value returned incorrectly

屏幕截图

  • Order field in add taxonomy term page
  • Order field in Quick Edit
  • Order field in edit taxonomy term page
  • Settings page

安装

  1. Upload the custom_taxonomy_sort folder to the /wp-content/plugins/ directory
  2. Activate the plugin through the ‘Plugins’ menu in WordPress

常见问题

After installation, what do I need to do?

After installing the plugin, all taxonomies will be automatically sorted by your custom order; however, you need to vist the individual taxonomy term edit pages to enter the order of the terms.

What is “Automatic Sort”

“Automatic Sort” has two states: “On” (default) and “Off”. When “Autmatic Sort” is set to “On”, every call to “get_terms” will be sorted by the custom sort order. In this mode, you do not have to manually add parameters to the “get_terms” function calls to have the terms sorted by the custom sort order. You can think of the “On” state as allowing the plugin to do everything for you; all you need to do is tell it in what order you want the terms to be sorted. On the other hand, if you set “Automatic Sort” to “Off”, you need to manually send parameters to the “get_terms” functions in order for the terms to be sorted by the custom sort order. The “Off” mode is best for developers who want absolute control over every time the terms are sorted and displayed.

What is “Sort Order”

“Sort Order” is the order in which the terms are sorted. “Ascending” will sort the terms from lowest to highest value (e.g., 1, 2, 3). “Descending” will sort the terms from highest to lowest value (e.g., 3, 2, 1).

评价

2016 年 9 月 3 日
Nice idea, but the plugin is quite severely broken and triggers nasty errors. The problems do go away if you remove the function name clashes which are in the simple-term-meta.php file. I’m guessing the errors have been occurring since WordPress 4.4 was released. So based on how long ago that was created, I’m assuming this plugin will never be updated :/
2016 年 9 月 3 日
I used to like this plugin, but it is not compatible with WordPress 4.4.2. I have to remove it and find the other plugin.
2016 年 9 月 3 日
Custom Taxonomy Sort broke my website- completely took it offline. I can only assume it is not compatible anymore with Wordpress and the developer seems to be long gone- his domain has expired and the plugin hasn’t been updated in years.
阅读所有15条评价

贡献者及开发者

「Custom Taxonomy Sort」是开源软件。 以下人员对此插件做出了贡献。

贡献者

更新日志

1.1.5

  • Fixed bug with returning an inappropriate value for “column_value”. Thanks to @martindj.

1.1.4

  • Fixed situation where the plugin will conflict with other changes to the term page columns. Thanks to DUCK__BOY1981.
  • Updated code to comply with WordPress coding standards

1.1.3

  • Fixed a potential situation where the custom sort does not work with “get_the_term_list”. Thanks to @anointed

1.1.2

  • Works for more custom taxonomies in more situations
  • Fixed column alignment
  • Localization fixes
  • Initial groundwork for column sorting

1.1.1

  • Fixed error message displayed in Post, Page, and Custom Post Type Quick Edit screens
  • Javascript and CSS only displays on taxonomy pages

1.1

  • Added full support for Quick Edit

1.0.1

  • Custom Sort is applied in more places (added filter to wp_get_object_terms)
  • Removed full support for WordPress 3.0 (will work in WordPress 3.0, but not in all places)

1.0

  • Initial release