可按Ctrl+D收藏 蚂蚁资源网

蚂蚁资源网

WordPress 添加Meta Box的方法

  • 时间:2020-11-25 22:20 编辑:陈罗密欧 来源:蚂蚁资源网 阅读:195
  • 扫一扫,手机访问
摘要:本文围绕WordPress   Meta   Box  讲述关于WordPress 添加Meta Box的方法的相关知识,精彩详情内容请仔细阅读以下内容。感谢支持!
大家好,今小编要介绍的是关于WordPress 添加Meta Box的方法的相关内容,多方面分析说明,感兴趣朋友的可以参考学习。

关键词:WordPress   Meta   Box  

相信很多站长都知道并且已经在使用WordPress自定义字段,很多插件也使用了这一功能。

自定义字段是一个非常不错的功能,它能够让我们为文章添加各种自定义的属性,高度灵活,操作简单。比如可以为文件添加一个SEO MetaDescription的自定义字段,我们可以输入一段文字来概括文章内容,在前台显示的时候可以根据该字段来生成HTML的<meta>标签,使搜索引擎更加方便的了解页面的内容,帮助索引。

但是,由于它的高度灵活,导致了一些问题,尤其因为自定义字段的值的输入是一个文本框,导致在输入时会非常不便,例如,设计的是一个整形的字段,但是由于文本框没有验证和提示,导致可能会输入非整数,在前台使用时就会出现问题,甚至导致网站挂掉。或者字段的值是预定义的值集合中的一个(比如有个性别的字段,就只是男和女中的一个值),但是文本框是不会提示你可以输入哪些值。

总的来说,不方便之处是文本框的单一输入方式无法满足不同场景下不同字段类型的输入需求和验证需求。

那么,解决方案来了,使用自定义Meta Box来自定义编辑页面。

以添加一个自定义字段——【推荐指数】为例,来讲讲如何使用Meta Box。

备注:推荐指数,在本例中指的是文章作者对文章的打分,分数在1~10分,为整数。分数越高,越推荐。
先来看看最终的样子,我们可以通过下拉列表来选择值了。




首先,需要使用到add meta boxes Action,该Action允许我们为任何文章类型注册Meta Box,在该Action中,我们需要使用add_meta_box()方法来添加Meta Box的相关信息。代码如下

PHP Code复制内容到剪贴板 functionadd_rating_meta_box($post_type,$post){ //需要哪些posttype添加推荐指数MetaBox $types=array('post','page'); foreach($typesas$type){ add_meta_box( 'rating_meta_box_id',//MetaBox在前台页面中的id,可通过JS获取到该MetaBox '推荐指数',//显示的标题 'render_rating_meta_box',//回调方法,用于输出MetaBox的HTML代码 $type,//在哪个posttype页面添加 'side',//在哪显示该MetaBox 'default'//优先级 ); } } add_action('add_meta_boxes','add_rating_meta_box');这里我们在$types数组中定义了Post和Page都需要推荐指数这个自定义字段,然后告诉WordPress使用“render_rating_meta_box”方法来渲染Meta Box,位置在侧边栏(side)。因为内容不多,所以侧边栏足够,若内容较多,可以将“side”改为“advanced”,这样就会在主内容区域渲染Meta Box。

接下来看看是如何渲染的
PHP Code复制内容到剪贴板 functionrender_rating_meta_box($post){ //添加nonce项用于后续的安全检查 wp_nonce_field('rating_nonce_action','rating_nonce_name'); //获取推荐指数的值 $rating_key='rating'; $rating_value=get_post_meta($post->ID,$rating_key,true); $rating_value=(int)$rating_value; $html='<selectname="rating_field">'; for($i=0;$i<=10;$i++){ $selected=''; if($i==$rating_value){ $selected='selected="selected"'; } $html.=sprintf('<optionvalue="%s"%s>%s星</option>',$i,$selected,$i/2); } $html.='</select>'; echo$html; }
这里先使用wp_nonce_field()添加了一个nonce field,用来做安全检查,然后,读取推荐指数的值,循环1~10来输出可供选择的值,如果和推荐指数相同,则默认选上。通过下拉框,既可以解决输入不方便和无法验证的问题。记住这里下拉框的name属性的值(rating_field),将通过它在下面的代码中获取选择的值。

最后,当文章被保存时,需要将推荐指数也保存起来
PHP Code复制内容到剪贴板 functionsave_rating_post_data($post_id){ //检查nonce是否设置 if(!isset($_POST['rating_nonce_name'])){ return$post_id; } $nonce=$_POST['rating_nonce_name']; //验证nonce是否正确 if(!wp_verify_nonce($nonce,'rating_nonce_action')){ return$post_id; } //如果是系统自动保存,则不操作 if(defined('DOING_AUTOSAVE')&&DOING_AUTOSAVE){ return$post_id; } //检查用户权限 if($_POST['post_type']=='post'){ if(!current_user_can('edit_post',$post_id)){ return$post_id; } } $rating_key='rating'; //获取数据 $rating_value=$_POST['rating_field']; //更新数据 update_post_meta($post_id,$rating_key,$rating_value); } add_action('save_post','save_rating_post_data');
这里做了一系列检查,包括对刚刚设置的nonce检查,用户权限的检查,排除自动保存的情况。然后使用update_post_meta()方法将数据存入数据库。

至此,我们就完成了对推荐指数自定义字段的改装,可以很方便的选择文章的推荐指数。

等等。。。

细心的朋友可能发现了,在应用了上面三段代码后,的确可以实现功能。但是,在默认的自定义栏目区域下,是可以看到,有一个名为“rating”的栏目,这就是我们刚刚选择的推荐指数。如果想让他不在自定义栏目下,显示,可以将上述代码中的$rating_key改为以下划线开头,这样,WordPress就不会显示出来了。注意有两个地方要改。

PHP Code复制内容到剪贴板 //原来的代码 $rating_key='rating'; //改后的代码 $rating_key='_rating';
以上就是WordPress 添加Meta Box的方法的全部内容,希望可以帮助到您。感谢对蚂蚁资源网的支持。
(责任编辑:陈罗密欧

版权声明:文章内容是蚂蚁资源网小编精心整合原创的,素材来源于互联网,如无意侵犯到您的权益,请联系网站客服核实版权信息,以便及时删除。
  • 全部评论(0)
最新发布的资讯信息
【简历/资料|内地女明星】 殷茹基本资料( YR个人简历介绍)(2020-12-06 15:19)
【简历/资料|内地女明星】 曹菁基本资料( CJ个人简历介绍)(2020-12-06 15:18)
【简历/资料|内地女明星】 王安妮基本资料( WAN个人简历介绍)(2020-12-06 15:18)
【简历/资料|内地女明星】 白琼基本资料( BQ个人简历介绍)(2020-12-06 15:17)
【简历/资料|内地女明星】 王世霞基本资料( WSX个人简历介绍)(2020-12-06 15:17)
【简历/资料|内地女明星】 宋煜基本资料( SY个人简历介绍)(2020-12-06 15:16)
【简历/资料|内地女明星】 钱增基本资料( QZ个人简历介绍)(2020-12-06 15:16)
【简历/资料|内地女明星】 胡晓黎基本资料( HXL个人简历介绍)(2020-12-06 15:15)
【简历/资料|内地女明星】 李佳慧基本资料( LJH个人简历介绍)(2020-12-06 15:15)
【简历/资料|内地女明星】 张洛嘉基本资料( ZLJ个人简历介绍)(2020-12-06 15:14)
联系客服
网站客服 联系客服
手机版

扫一扫进手机版
返回顶部