WordPress 添加Meta Box的方法-新华站长网

博客给出了在WordPress中添加推荐指数MetaBox的代码。包含添加MetaBox、渲染HTML代码、保存数据等功能函数,还涉及nonce安全检查、用户权限验证等。最后展示了一处代码修改,将`rating_key`从`rating`改为`_rating`。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

相信很多站长都知道并且已经在使用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复制内容到剪贴板
  1. functionadd_rating_meta_box($post_type,$post){ //需要哪些posttype添加推荐指数MetaBox
  2. $types=array('post','page');
  3. foreach($typesas$type){ add_meta_box(
  4. 'rating_meta_box_id',//MetaBox在前台页面中的id,可通过JS获取到该MetaBox '推荐指数',//显示的标题
  5. 'render_rating_meta_box',//回调方法,用于输出MetaBox的HTML代码 $type,//在哪个posttype页面添加
  6. 'side',//在哪显示该MetaBox 'default'//优先级
  7. ); }
  8. } 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复制内容到剪贴板
  1. functionrender_rating_meta_box($post){ //添加nonce项用于后续的安全检查
  2. wp_nonce_field('rating_nonce_action','rating_nonce_name');
  3. //获取推荐指数的值 $rating_key='rating';
  4. $rating_value=get_post_meta($post->ID,$rating_key,true); $rating_value=(int)$rating_value;
  5. $html='<selectname="rating_field">';
  6. for($i=0;$i<=10;$i ){ $selected='';
  7. if($i==$rating_value){ $selected='selected="selected"';
  8. } $html.=sprintf('<optionvalue="%s"%s>%s星</option>',$i,$selected,$i/2);
  9. } $html.='</select>';
  10. echo$html; }

这里先使用wp_nonce_field()添加了一个nonce field,用来做安全检查,然后,读取推荐指数的值,循环1~10来输出可供选择的值,如果和推荐指数相同,则默认选上。通过下拉框,既可以解决输入不方便和无法验证的问题。记住这里下拉框的name属性的值(rating_field),将通过它在下面的代码中获取选择的值。

最后,当文章被保存时,需要将推荐指数也保存起来
PHP Code复制内容到剪贴板
  1. functionsave_rating_post_data($post_id){ //检查nonce是否设置
  2. if(!isset($_POST['rating_nonce_name'])){ return$post_id;
  3. } $nonce=$_POST['rating_nonce_name'];
  4. //验证nonce是否正确
  5. if(!wp_verify_nonce($nonce,'rating_nonce_action')){ return$post_id;
  6. }
  7. //如果是系统自动保存,则不操作 if(defined('DOING_AUTOSAVE')&&DOING_AUTOSAVE){
  8. return$post_id; }
  9. //检查用户权限
  10. if($_POST['post_type']=='post'){ if(!current_user_can('edit_post',$post_id)){
  11. return$post_id; }
  12. }
  13. $rating_key='rating'; //获取数据
  14. $rating_value=$_POST['rating_field'];
  15. //更新数据 update_post_meta($post_id,$rating_key,$rating_value);
  16. } add_action('save_post','save_rating_post_data');

这里做了一系列检查,包括对刚刚设置的nonce检查,用户权限的检查,排除自动保存的情况。然后使用update_post_meta()方法将数据存入数据库。

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

等等。。。

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

PHP Code复制内容到剪贴板
  1. //原来的代码 $rating_key='rating';
  2. //改后的代码 $rating_key='_rating';
新华站长网 - 免责声明1、本文出自 新华站长网,转载或引用本文时请注明出处!
2、原文地址: http://www.xhxu.com/article-120389-1.html
3、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
4、点击访问 新华站长网获得更多免费的教程及整站源码
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

百度资源网

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值