Simple Page Ordering


Order your pages, hierarchical custom post types, or custom post types with «page-attributes» with simple drag and drop right from the built in page list.

Simply drag and drop the page into the desired position. It’s that simple. No new admin menus pages, no clunky, bolted on user interfaces. Just drag and drop on the page or post-type screen.

The plug-in is «capabilities aware» – only users with the ability to edit others’ pages (editors and administrators) will be able to reorder content.

Integrated help is included: just click the «help» tab at the top right of the screen.

Please note that the plug-in is not compatible with Internet Explorer 7 and earlier, due to limitations within those browsers.


We’d love to have you join in on development over on GitHub.


  • Dragging the page to its new position
  • Processing indicator


  1. Install either via the plugin directory, or by uploading the files to your server.
  2. Activate the plugin through the ‘Plugins’ menu in WordPress.
  3. Get to work reordering your content!


Why can’t I reorder my posts?

Generic posts are not displayed by menu order – they’re displayed by chronology. You can theoretically add menu ordering to posts in your code (theme functions.php, plug-in) by using:

add_post_type_support( 'post', 'page-attributes' );

Can I make my custom post type take advantage of this plug-in?

Yep. There are two ways to turn on support for Simple Page Ordering.

Ideally, when you register the post type, set hierarchical to true – hierarchical post types natively order by menu order.

Alternatively, when you define the features the post type supports, include page-attributes. This will add a Sort by Order option to the filter links above the drop downs. Once you sort by order, you can drag and drop the content.

Finally, you can take advantage of the simple_page_ordering_is_sortable filter, which passes the result of the default check and the post type name, to override default behavior.

I want my non-hierarchical post type to be sortable. Help!

See the previous two answers – just add page-attributes to the list of supported post type features.

I reordered my posts, but the order didn’t change on the front end of my site!

This plug-in doesn’t change any behavior on the front end, it simply changes the menu order stored in WordPress.

If you want a list of pages or custom post types to display in that defined order, you must change the post query’s orderby parameter to menu_order (if it’s not already).

I reordered my content, it seemed to work, but when I refreshed, it went back to the old order!

This most likely means the AJAX request – the server side code – failed after you dropped the content into the new position. Some shared hosts aggressively time out and limit AJAX requests. Version 2.0 batches these requests so you can try reducing the number of items it updates on each request using a filter in your theme’s functions.php or a custom plug-in:

add_filter( 'simple_page_ordering_limit', function($number) { return 5; } );

Where 5 is the number of items to batch on each request (the default is 50). Note that this example uses PHP 5.3+ callback functions, so if you’re still on PHP 5.2, you’ll need to add a traditional callback.

What happened to the drop down box that let me change the number of items on each page in the admin??

This feature is already built into WordPress natively, but a bit tucked away. If you pull down the «Screen Options» tab up top (on the list of post objects) there’s a field where you can specify the number of items to show per page. I decided it was not a very good practice to duplicate this.


20 de septiembre de 2021
Have a site with 100+ pages, needed a way to visually set the menu_order attribute without having to setting them individually. I also didn't want to rely on another plugin's system to maintain the order. This was exactly what I needed. Thank you
19 de abril de 2021
We like to organize our pages for our Clients using Happy Files. Within each "folder", we organize our pages either in menu order, workflow order or order of importance. This makes finding and managing pages super easy for our Clients. We couldn't do it without this plugin. THANK YOU.
25 de febrero de 2021
No hassle, just install and start drag and drop pages in any order. Tested in combination with and works as expected. Thanks a lot for great job.
29 de mayo de 2020
Just tried this plugin after having struggled with the hierarchical sorting for a long time. It does what was announced, but in a stupid way. Careful: this plugin changes the hierarchy-level and the sort# of your pages, without informing you first. This is like cheating. Of course I can cheat myself and assign wrong parameters to a page to force its position in the pages-list. But this is not what I had hoped for. Our need is this: We have three different versions (contentwise) of each page, so our triplets share the same position in the hierarchy of course. Many pages have sub-pages, but we want the triplets to always show up next to each other in the list, to help us with editing. We hate the way WordPress is crawling the tree, going first all the way down into one branch before going back up to higher levels. WordPress is giving us a hierarchy for pages, but gives higher priority to the alphabet than to the hierarchy-level when displaying the list. Yikes. We had hoped this plugin would help us, but it does not. We need to see a list of all our pages strictly sorted by hierarchy, like this example: (Any ideas please?) Superdad Superdad's twin sister Superdad's twin brother -Superson (son of Superdads twin sister but not important for our list view needs) -Superson's twin brother -Superson's other twin brother -Supersecondson -Supersecondson's twin sister -Supersecondson's other twin sister --Supergranddaughter (daughter of any of the above six pages but no need to see it) --Supergranddaughter's twin sister --Supergranddaughter's twin brother I give three stars because I looked all over before I installed and tried to learn how this plugin does the magic. There is no documentation about "the active ingredient". I was thinking it would internally rename the page-id or something (and hoped it would do it properly and not break our website). If you help me find a solution (since you guys know all about sorting) I will gladly give you five stars and make a mention here that yours is not our solution but how you helped me find our own solution. Thanks.
Leer todas las 118 reseñas

Colaboradores y desarrolladores

«Simple Page Ordering» es un software de código abierto. Las siguientes personas han colaborado con este plugin.


«Simple Page Ordering» ha sido traducido a 27 idiomas locales. Gracias a los traductores por sus contribuciones.

Traduce «Simple Page Ordering» a tu idioma.

¿Interesado en el desarrollo?

Revisa el código , echa un vistazo al repositorio SVN o suscríbete al registro de desarrollo por RSS.

Registro de cambios


  • Changed: Avoid failed reordering introduced in v2.3.3 when handling a large number of non-hierarchical items (props @dinhtungdu)
  • Changed: Bump WordPress version support to 5.4 (props @tmoorewp)
  • Fixed: Ensure titles of reordered items appear in a human-readable way (props @dinhtungdu)



  • Added: Allow cancellation of drag operation by pressing escape key
  • Fixed: Allow form input elements added to a row by plugins to be interacted with


  • Fixed: Prevent rows with hidden columns from jumping around while dragging


  • Added: Use WordPress core’s spinner class
  • Added: Grunt-based build process with Sass
  • Changed: Use WP_Query instead of get_posts() for better performance
  • Changed: Remove bundled translations in favor of language packs
  • Fixed: Avoid exceeding PHP’s max input variables, which could cause incorrectly assigned page order
  • Fixed: Malformed URL that would take you to posts instead of pages
  • Fixed: PHPDoc and coding standards to align with 10up’s Engineering Best Practices


  • Fixed: Redundant URL encoding when sorting in admin page list


  • Fixed: Ordering in WordPress 4.0 following core changes to ORDER BY in WP_Query


  • Added: German localization (props @glueckpress)
  • Fixed: Column widths no longer change when dragging a row (partial props @griffinjt)
  • Security: Closed obscure XSS vulnerability related to Sort by Order link (props @simon-waters)


  • Added: Brazilian translation (props @felds)
  • Fixed: Bring back translations / text domain (yikes!)


  • Changed: Look and feel to better match WordPress 3.8 admin redesign
  • Changed: Improved awareness of and compatibility with Quick Edit (inline editor)
  • Fixed: Prevent collisions with themes and plugins bundling Simple Page Ordering


  • Fixed: Hierarchical custom post types without page-attributes was still broken – doh!
  • Fixed: Extreme edge case where post columns did not include the post title now supported


  • Fixed: custom post types with page-attributes or hierarchical properties, but not both, breaking ordering


  • Added: Awareness of custom user capabilities for post types, in addition to a filter (simple_page_ordering_edit_rights) for overriding reordering rights (previously used edit_others_pages globally)
  • Added: Awareness of custom post statuses (so they are not skipped during backend ordering operation)
  • Changed: UI refinements: Better «spinner» positioning (and HiDPI), translucent row when moving, improved appearance of «drop» placeholder, wait till row dragged by at least 5px to start sorting
  • Changed: Major JavaScript refactoring and simplification (combined with new stylesheet) for better performance


  • Added: Drag pages into any part of the page hierarchy! No longer limited to same branch of tree!
  • Added: Big performance improvements under the hood: leaner queries, batched requests, less processing
  • Added: New filters and hooks to extend / override default functionality
  • Changed: Scales much more reliably in situations with very high page counts due to batching of requests
  • Changed: Order of the first page is now set to «1» instead of «0», so pages added after ordering are added at the top (instead of second)
  • Changed: Removed «number of pages» drop down, which is repetitive of a field accessible under Screen Options
  • Changed: Improved compatibility with newer versions of WordPress


  • Added: Support for ordering non-hierarchical post types that have «page-attributes» support
  • Added: New filter link for «Sort by Order» to restore (hierarchical) or set (non-hierarchical, page attributes support) post list sort to menu order
  • Changed: Users are now forced to wait for current sort operation to finish before they can sort another item
  • Changed: Smarter about «not sortable» view states
  • Changed: Localization ready! Rough Spanish translation included.
  • Changed: Assorted other performance and code improvements
  • Fixed: Unexpected page ordering results when pages have not been explictly ordered yet (sorts by menu_order, then title, not just menu_order)
  • Fixed: «Per page» drop down filter selection not saving between page loads (was broken in 3.1)
  • Fixed: Items are always ordered with positive integers (potential negative sort orders had some performance benefits in last version, but sometimes caused issues)


  • Fixed: for broken inline editing (quick edit) fields in Firefox


  • Changed: Smarter awareness of «sorted» modes in WordPress 3.1 (can only use when sorted by menu order)
  • Changed: Smarter awareness of «quick edit» mode (can’t drag)
  • Changed: Generally simplified / better organized code


  • Added: Further directions in the plug-in description (some users were confused about how to use it)
  • Added: Basic compatibility with 3.1 RC (prevent clashes with post list sorting)
  • Changed: «Move» cursor only set if JavaScript enabled
  • Fixed: Page count display always showing «0» on non-hierarchical post types (Showing 1-X of X)
  • Fixed: Hidden menu order not updating after sort (causing Quick Edit to reset order when used right after sorting)


  • Changed: Loosened constraints on drag and drop to ease dropping into top and bottom position
  • Changed: Improved some terminology (with custom post types in mind)
  • Fixed: Row background staying «white» after dropping into a new position
  • Fixed: Double border on the bottom of the row while dragging


  • Changed: Simplified code – consolidated hooks
  • Changed: Updated version requirements