If you&#x2019;ve been using WordPress for a while, you might not have noticed the screen options that were added a few versions ago. You can change the number of posts or pages shown per page in the Edit screens, and you can hide some of the columns if you like.
On the menu screen, the screen options allows you to show things that are normally hidden, like custom post types and taxonomies.
On the Dashboard, the screen options let you choose the number of columns your widgets are displayed in, and you can turn off individual widgets.
The bulk edit feature is also easy to overlook. Check off several posts in the Edit screen, then choose &#x201C;Edit&#x201D; from the Bulk Actions dropdown. You&#x2019;ll be able to edit all the attributes of the posts: categories, tags, comment/trackback settings, publication status, and sticky status. You won&#x2019;t be able to edit things that are naturally unique to each post, like the title and date.
Did you know there&#x2019;s a members-only content feature built right into WordPress? It&#x2019;s a little buggy, which is probably why it&#x2019;s not more well-known. If you change a post or page to privately published, only logged-in users who can see private posts and pages will be able to see it.
This is Justin Tadlock&#x2019;s Members plugin. Among other things, you can choose which roles can edit or read private posts and pages -- or you can create a whole new role for that purpose.
My own Private Suite plugin also lets you choose roles for reading private content.
the_shortlink() is a new function in 3.0. It lets you print a shorter permalink for your post in your template file for readers to use. If you have the WordPress Stats plugin installed, you&#x2019;ll see wp.me links (although you can turn that off in the plugin&#x2019;s settings). If not, you&#x2019;ll see the default permalink structure (example.com/?p=123), which always works no matter what permalink structure you&#x2019;ve chosen.
The Incoming Links and the two WordPress news Dashboard widgets are just RSS readers. Click &#x201C;configure&#x201D; in the upper right corner of each widget, and you&#x2019;ll be able to change the RSS feed that&#x2019;s shown.
Type options.php into your address bar (example.com/wp-admin/options.php) and you&#x2019;ll get this alphabetized listing of all the options stored in your wp_options database table. Some won&#x2019;t be editable -- if they&#x2019;re stored as arrays, you&#x2019;ll just see &#x201C;Serialized data&#x201D; -- but the rest can be changed here. Be careful with this!
You can edit serialized options by changing the database fields directly. Copy the serialized array (shown here in the row with the ID 10390) and paste it into the Online PHP Unserializer at blog.tanist.co.uk. This tool will convert the serialized array to a more familiar array printout. You can then make changes and re-serialize the array to store it back in the database.
WordPress automatically generates feeds for just about everything. Most of the time, the feeds for posts and comments are the only ones you see. For anything else, just add /feed to the URL and see what happens! You can get feeds for categories, tags, combinations of tags...
... individual authors&#x2019; posts, post types (including pages!), taxonomy terms, and even search terms.
This is where you&#x2019;ll have to get your hands dirty with code. Filters allow you to change the way content is handled or displayed in WordPress sites.
For example, you can easily allow users to use shortcodes in text widgets by adding these two lines to your functions.php file.
It&#x2019;s also easy to automatically list child pages on a parent page with empty content using this filter. (See my website for alternatives using shortcodes and template tags.)
This filter alters the contact fields that are shown in user profiles. Here, I&#x2019;ve removed the three IM fields and added Twitter, a phone number, and a job title.
Here&#x2019;s how the new contact fields appear.
With the new fields in place, it&#x2019;s easy to build a robust user directory. (See this URL for details on limiting the directory to certain roles.)