WordPress默认内置文章状态以及添加自定义文章状态代码
WordPress每次发布都会有文章转态编辑的内容,除了未发布前展示的草稿状态,其实它还有一些其他的内置的默认文章状态,同时我们还可以自己通过添加代码来实现添加自定义文章状态。下面具体看一看哪些是WordPress默认的内置文章状态,以及我们该怎么添加自定义的文章状态。
WordPress默认内置了以下几种文章状态:
草稿 – 已保存但尚未完成且尚未发布的文章
自动草稿 – WordPress具有自动保存功能,可自动将草稿保存为修订版
待审核 – 已完成并提交审核但尚未发布的文章
未来 – 计划稍后定时发布的文章,也就是通过上图设置发布时间为未来某个时间点即可
私密 – 标记为私密的文章,只有自己登录后可见
回收 – 被添加到回收站的文章
继承 – 自动继承其父页面状态的子页面
当然,除了这些默认的文章状态以外,我们还可以添加自定义的文章状态,具体代码示例如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 |
// 注册新的文章状态 function wpdx_add_custom_post_status(){ register_post_status('rejected', array( 'label' => _x( 'Rejected', 'post' ), 'public' => false, 'exclude_from_search' => false, 'show_in_admin_all_list' => true, 'show_in_admin_status_list' => true, 'label_count' => _n_noop( 'Rejected <span class="count">(%s)</span>', 'Rejected <span class="count">(%s)</span>' ), ) ); } add_action( 'init', 'wpdx_add_custom_post_status' ); // 通过js添加新的状态到文章编辑页面 function wpdx_add_post_status_list(){ global $post; $complete = ''; $label = ''; if($post->post_type == 'post'){ //只对默认的post类型添加 if($post->post_status == 'rejected'){ $complete = ' selected="selected"'; $label = '<span id="post-status-display"> Rejected</span>'; } echo ' <script> jQuery(document).ready(function($){ $("select#post_status").append("<option value=\"rejected\" '.$complete.'>Rejected</option>"); $(".misc-pub-section label").append("'.$label.'"); }); </script> '; } } add_action('admin_footer-post.php', 'wpdx_add_post_status_list'); add_action('admin_footer-post-new.php', 'wpdx_add_post_status_list'); // 通过js添加新的状态到文章列表的快速编辑 function wpdx_add_custom_status_in_quick_edit() { echo "<script> jQuery(document).ready( function($) { $( 'select[name=\"_status\"]' ).append( '<option value=\"rejected\">Rejected</option>' ); }); </script>"; } add_action('admin_footer-edit.php','wpdx_add_custom_status_in_quick_edit'); |
上面的代码示例注册了新的文章状态:Rejected,请根据你的实际需要,修改代码中高亮显示的行中的大小写的 Rejected,才能完全设置为你自己的文章状态!
由于WordPress自身存在一个bug:新注册的文章状态不会自动添加到设置选择中,所有上面就只能通过js方式添加选择,这个bug已经提交了好几年了,不清楚为什么WordPress官方一直没有修复。
最终的效果如下面图中所示:
此外当文章状态更新了之后,还想做一些类似发邮件通知的一些操作,还可以尝试下插件 Post Status Notifier 和 Post Status Notifications ,以及一款不错的编辑流程 Edit Flow 的自定义状态也都可以多了解些。后面如果有需要也可以和大家分享下。
您或许对下面这些文章有兴趣: 本月吐槽辛苦排行榜
- 不用插件WordPress怎样实现自动设置tag标签自动内链?
- 当前WordPress最好用的几个备份插件对比
- WordPress最新发布的版本WordPress 5.0.3 修复了37个错误
- WordPress 如何添加 Democracy Poll 投票问卷调查功能
- 用Local by Flywheel给WordPress搭建本地运行环境:如何创建和管理站点
- 关于使用Local by Flywhee给WordPress搭建本地运行环境的简介和安装
- WordPress 5.0发布新的Gutenberg默认编辑器和主题
- 怎么利用插件OSS Upload实现WordPress媒体文件阿里云OSS分离存储