Add subtitles (subheadings) to your pages, posts or custom post types.
The WP Subtitle plugin allows your pages and posts to contain a subtitle. Also called a sub-heading, this this short line of text is meant to appear beneath a post's (or page's) title, but can be inserted in your template wherever you choose.
The subtitle can be inserted into your theme template files (or plugin) using the following API:
All parameters are optional. If 'post_id' is omitted then the current post ID in the loop is used.
PHP Code:
do_action( 'plugins/wp_subtitle/the_subtitle', array(
'before' => '<p class="subtitle">',
'after' => '</p>',
'post_id' => get_the_ID(),
'default_value' => ''
) );
Output:
<p class="subtitle">My Post Subtitle</p>
All parameters are optional. If 'post_id' is omitted then the current post ID in the loop is used.
A default value can be supplied as the second parameter for apply_filters
. This will be used if the post does not have a subtitle. Leave as an empty string to return an empty string if the post does not have a subtitle.
PHP Code:
$subtitle = apply_filters( 'plugins/wp_subtitle/get_subtitle', '', array(
'before' => '<p class="subtitle">',
'after' => '</p>',
'post_id' => get_the_ID()
) );
Result:
$subtitle = '<p class="subtitle">My Post Subtitle</p>'
The array of arguments accepted for the plugins/wp_subtitle/the_subtitle
action and plugins/wp_subtitle/get_subtitle
filter are:
before
(string) Text to place before the subtitle if one exists. Defaults to an empty string.
after
(string) Text to place after the subtitle if one exists. Defaults to to an empty string.
post_id
(integer) Post, page or custom post type ID.
default_value
(string) Only used by the plugins/wp_subtitle/the_subtitle
action, allows you to specify a default subtitle to display if the post does not have one. For the plugins/wp_subtitle/get_subtitle
filter the second parameter of apply_filters
should be used instead. Defaults to to an empty string.
By default, subtitle are supported by both posts and pages. To add support for custom post types add teh following to your theme functions file or plugin:
add_post_type_support( 'my_post_type', 'wps_subtitle' )
Subtitles can automatically be added to your WooCommerce products without needing to make template changes. In the admin go to WooCommerce > Settings > Products where you can choose to:
- Enable Product Subtitles
- Display the subtitle on single product pages
- Display the subtitle on product archives (category pages)
The plugin allows you to include the subtitle in your meta titles and descriptions via the Yoast SEO and SEOPress plugins.
Similar to the Yoast %%title%%
placeholder which inserts the post title, you can use %%wps_subtitle%%
.
There are also addition placeholders and filters to allow to to customize seperators for the subtitle.
For more information, view the SEO support documentation here.
- Upload the WP Subtitle plugin to your WordPress site in the
/wp-content/plugins
folder or install via the WordPress admin. - Activate it from the Wordpress plugin admin screen.
- Use the API to display the subtitle in your theme.
For full details on the API and how to display the subtitle, view the documentation here.
What does WP Subtitle do?
The plugin adds a Subtitle field when editing posts, pages or custom post types. The subtitle is stored as a custom field (post meta data) and can be output using API actions and filters.
Where does WP Subtitle store the subtitles?
All subtitles are stored as post meta data. Deactivating this plugin will not remove those fields.
Compatibility with WordPress 5.0+
In the new editor in WordPress 5.0 the subtitle is editable via a panel in the sidebar (like excerpts).
How do I add the subtitle to my pages?
Refer to the documentation.
How do I add support for custom post types?
To add support for custom post types add the following to your theme functions file or plugin:
function my_wp_subtitle_page_part_support() {
add_post_type_support( 'my_post_type', 'wps_subtitle' );
}
add_action( 'init', 'my_wp_subtitle_page_part_support' );
Where can I get help?
Please post support requests and questions in the WordPress.org Support forum.
How should I report a bug?
Please submit bugs/errors directly to the GitHub Issues list.
How can I contribute code?
The plugin is hosted on GitHub and pull requests are welcome.
Resolve XSS issue by improving sanitization when saving subtitle custom field.
Added support for the SEOPress plugin and updating the subtitle via the REST API.
Fixed broken closing H2 tag for WooCommerce subtitle.
New API for getting and displaying the subtitle using do_action( 'plugins/wp_subtitle/the_subtitle' )
and apply_filters( 'plugins/wp_subtitle/get_subtitle', '' )
. Please see the documentation.
Fix WordPress 5.0 compatibility.
WooCommerce compatibility: Go to WooCommerce > Settings > Products > Display
for settings. Yoast SEO compatibility: Added %%wps_subtitle%%
placeholders. Gutenberg compatibility: Use metabox UI.
Make wps_subtitle
available via WordPress REST API.
Fix preview not rendering correct template and other post meta.
Add support for revisions and fix special character encoding.
Fix PHP warning - get_admin_subtitle_value()
should be declared static.
Allow subtitle to contain HTML (same as main post title ) and add wps_default_subtitle
filter.
Fix incorrect post ID reference preventing subtitle from saving.
Trim subtitle and wptexturize() by default.
Added quick edit support for subtitle. Security Update: Sanitize $_REQUEST
and $_GET
when establishing post type in the admin.
Add [wp_subtitle] shortcode. Do not use variable for textdomain - causes issues for parsers.
Fix PHP notice warning on 404 error page.
Add subtitle admin column.
Security Update: Ensure subtitles are sanitized when saving.
Prevent subtitle fields from displaying on unsupported post types and fix issue with quotes in subtitles.
Subtitle field moved to below title field (only in WordPress 3.5+)
Fixed static method warnings and only load admin functionality when needed.
Added custom post type support and support for more recent versions of WordPress.
Initial release.
View a list of all plugin changes in CHANGELOG.md.