关注VPS主机与
服务器促销分享

给WordPress的文章添加自定义文章状态及添加自定义状态的代码

WordPress每次发布都会有文章转态编辑的内容,除了未发布前展示的草稿状态,其实它还有一些其他的内置的默认文章状态,同时我们还可以自己通过添加代码来实现添加自定义文章状态。下面具体看一看哪些是WordPress默认的内置文章状态,以及我们该怎么添加自定义的文章状态。

WordPress默认内置了以下几种文章状态:

  • 草稿 – 已保存但尚未完成且尚未发布的文章
  • 自动草稿 – WordPress具有自动保存功能,可自动将草稿保存为修订版
  • 待审核 – 已完成并提交审核但尚未发布的文章
  • 未来 – 计划稍后定时发布的文章,也就是通过上图设置发布时间为未来某个时间点即可
  • 私密 – 标记为私密的文章,只有自己登录后可见
  • 回收 – 被添加到回收站的文章
  • 继承 – 自动继承其父页面状态的子页面

当然,除了这些默认的文章状态以外,我们还可以添加自定义的文章状态,具体代码示例如下:

// 注册新的文章状态
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 的自定义状态也都可以多了解些。

赞(0)
版权声明:本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权, 转载请注明出处。
文章名称:《给WordPress的文章添加自定义文章状态及添加自定义状态的代码》
文章链接:https://www.zyhot.com/article/3934.html
关于安全:任何IDC都有倒闭和跑路的可能,月付和备份是您的最佳选择,请保持良好的、有规则的备份习惯。
本站声明:本站仅做信息分享,不参与任何交易,也非中介,仅记录个人感兴趣的主机测评结果和优惠活动,内容均不作直接、间接、法定、约定的保证。访问本站请务必遵守有关互联网的相关法律、规定与规则。一旦您访问本站,即表示您已经知晓并接受了此声明通告。

评论 抢沙发

评论前必须登录!

 

登录

找回密码

注册