我的编程空间,编程开发者的网络收藏夹
学习永远不晚
位置:首页-资讯-开源

WordPress 添加Meta Box的方法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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复制内容到剪贴板

  1. function add_rating_meta_box($post_type$post) {   
  2.     // 需要哪些post type添加推荐指数 Meta Box   
  3.     $types = array'post''page' );   
  4.        
  5.     foreach ( $types as $type ) {   
  6.         add_meta_box(   
  7.             'rating_meta_box_id'// Meta Box在前台页面中的id,可通过js获取到该Meta Box   
  8.             '推荐指数'// 显示的标题   
  9.             'render_rating_meta_box'// 回调方法,用于输出Meta Box的HTML代码   
  10.             $type// 在哪个post type页面添加   
  11.             'side'// 在哪显示该Meta Box   
  12.             'default' // 优先级   
  13.         );   
  14.     }   
  15. }   
  16. 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. function render_rating_meta_box( $post ) {   
  2.     // 添加 nonce 项用于后续的安全检查   
  3.     wp_nonce_field( 'rating_nonce_action''rating_nonce_name' );   
  4.   
  5.     // 获取推荐指数的值   
  6.     $rating_key = 'rating';   
  7.     $rating_value = get_post_meta( $post->ID, $rating_key, true );   
  8.     $rating_value = (int)$rating_value;   
  9.   
  10.     $html = '<select name="rating_field">';   
  11.     for ($i = 0; $i <= 10; $i++) {   
  12.         $selected = '';   
  13.         if ($i == $rating_value) {   
  14.             $selected = 'selected="selected"';   
  15.         }   
  16.         $html .= sprintf('<option value="%s" %s>%s星</option>'$i$selected$i/2);   
  17.     }   
  18.     $html .= '</select>';   
  19.     echo $html;   
  20. }  

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

最后,当文章被保存时,需要将推荐指数也保存起来

PHP Code复制内容到剪贴板

  1. function save_rating_post_data( $post_id ) {   
  2.     // 检查nonce是否设置   
  3.     if (!isset($_POST['rating_nonce_name'])) {   
  4.         return $post_id;   
  5.     }   
  6.     $nonce = $_POST['rating_nonce_name'];   
  7.   
  8.     // 验证nonce是否正确   
  9.     if (!wp_verify_nonce( $nonce'rating_nonce_action')) {   
  10.         return $post_id;   
  11.     }   
  12.   
  13.     // 如果是系统自动保存,则不操作   
  14.     if ( defined( 'DOING_AUTOSAVE' ) && DOING_AUTOSAVE ) {   
  15.         return $post_id;   
  16.     }   
  17.        
  18.     // 检查用户权限   
  19.     if ($_POST['post_type'] == 'post') {   
  20.         if (!current_user_can('edit_post'$post_id )) {   
  21.             return $post_id;   
  22.         }   
  23.     }   
  24.   
  25.     $rating_key = 'rating';   
  26.     // 获取数据   
  27.     $rating_value = $_POST['rating_field'];   
  28.   
  29.     // 更新数据   
  30.     update_post_meta( $post_id$rating_key$rating_value );   
  31. }   
  32. add_action( 'save_post''save_rating_post_data' );  

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

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

等等。。。

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

PHP Code复制内容到剪贴板

  1. // 原来的代码   
  2. $rating_key = 'rating';   
  3. // 改后的代码   
  4. $rating_key = '_rating';   

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

WordPress 添加Meta Box的方法

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

WordPress 添加Meta Box的方法

相信很多站长都知道并且已经在使用WordPress自定义字段,很多插件也使用了这一功能。 自定义字段是一个非常不错的功能,它能够让我们为文章添加各种自定义的属性,高度灵活,操作简单。比如可以为文件添加一个SEO MetaDescriptio
2022-06-12

Dreamweaver中box shadow添加阴影的方法

这篇文章主要介绍Dreamweaver中box shadow添加阴影的方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Dreamweaver中box shadow添加阴影的方法1、打开Dreamweaver软件,c
2023-06-08

WordPress添加前台注册功能的方法

本文实例讲述了WordPress添加前台注册功能的方法。分享给大家供大家参考。具体分析如下: WordPress属于个人博客型的开源系统,是不是具备前台注册功能的,下面我来介绍自己给WordPress增加一个会员注册功能,有需要的朋友可参考
2022-06-12

WordPress 搜索框添加文字提示的方法

如在 Nicky 的博客中, 我发现了下图中的搜索栏.在搜索栏中添加这样的提示信息, 可以引导访客对网站进行搜索, 对技术类, 分享类网站尤其有效. 为了保持良好的用户体验, 我们一般会在搜索之后保留上次搜索的关键字, 如下图是搜索 'Wo
2022-06-12

wordpress主题评论中添加回复的方法

本文实例讲述了wordpress主题评论中添加回复的方法。分享给大家供大家参考。具体如下: 很多朋友要给自己主题评论加个@reply回复效果,都会选择用插件,其实我们可以完全修改源码来实现,这里就来给大家介绍wordpress主题评论中怎么
2022-06-12

为WordPress添加文章字数统计的方法

WordPress在后台编辑日志时编辑框左下角有一个字数统计,不过只显示在后台,能不能在前台也加上文章字数统计功能呢?研究了一下程序源文件,发现中文版WP后台的字数统计功能,是通过wp-content\languages目录的zh_CN-w
2022-06-12

WordPress评论添加楼层显示的方法小结

本文实例总结了WordPress评论添加楼层显示的方法。分享给大家供大家参考。具体分析如下: 第一步:要在评论中增加楼号显示,也就是要更改WordPress的评论内部结构。 第二步:WP中的评论是统www.cppcns.com一标号的,也就
2022-06-12

WordPress快速添加友情链接功能的方法

本文实例讲述了WordPress快速添加友情链接功能的方法。分享给大家供大家参考。具体方法分析如下: WordPress系统默认下是没有友情链接功能的,为了网站更好的优化我们需对它加个友情连接功能,下面我把我在wordpress中增加友情链
2022-06-12

wordpress如何添加Html5的表单验证required方法

这篇文章将为大家详细讲解有关wordpress如何添加Html5的表单验证required方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。表单验证 是防止垃圾评论的一个方面,wordpress已经自带了
2023-06-09

​利用WordPress自带短代码添加视频的方法

这篇文章主要介绍利用WordPress自带短代码添加视频的方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!利用WordPress自带短代码添加视频利用WordPress自带的视频短代码可以方便地让你在任何位置添加视
2023-06-14

在wordpress文章末尾添加内容的简单方法

1、修改文章页面模板single.php打开模版文件中的single.php,在其中搜索在这行下面加上:复制代码代码如下:

原创文章如转载,请注明本文链接:

WordPress中添加语音搜索功能的实现方法

本文实例讲述了WordPress中添加语音搜索功能的实现方法。分享给大家供大家参考。具体分析如下: WordPress可以增加一个语音搜索功能,编程客栈但是此功能暂时只能Chrome浏览器上使用,因为必须使用x-webkit-speech,
2022-06-12

WordPress给文章图片自动添加链接的方法

本文实例讲述了WordPress给文章图片自动添加链接的方法。分享给大家供大家参考。具体分析如下: 我们会看到有很多的网站我们点击图片就会进入当前文件连接了,下面我来给使用wordpress博客的同学也来介绍此种方法,图片自动链接到文章,添
2022-06-12

WordPress投稿功能添加邮件提醒功能的方法

一、添加一个存储投稿者邮箱的自定义栏目打开WordPress添加投稿功能,下面我们将对这篇文章中的代码进行修改。在第二段代码第78行插入以下代码: // 其中 ludou_tougao_email 是自定义栏目的名称 add_post_me
2022-06-12

WordPress自动给文章添加nofollow属性的实现方法

本文实例讲述了WordPress自动给文章添加nofollow属性的实现方法。分享给大家供大家参考。具体分析如下: nofollow属性是告诉搜索引擎不传权重过去,但WordPressk中如果我们要nofollow属性就需要手工加了,现在我
2022-06-12

wordpress编辑器中添加链接功能自动加入nofollow的方法

因为偶尔加一些站外链接,一般都是nofollow,单独写入很麻烦,所以琢磨从编辑器入手,通过这个插件(http://wordpress.org/plugins/nofollow/)了解功NHRSCQnA能,手动修改js代码实现了自动添加no
2022-06-12

WordPress文章标题链接添加正在加载中提示的方法

本文实例讲述了WordPress文章标题链接添加正在加载中提示的方法。分享给大家供大家参考。具体分析如下: 我们会看到很多使用wordpress博客的朋友我们点击文章标题时就会先提示正在加载中,然后再进入文章了,这里我们就来给大家介绍Wor
2022-06-12

如何为WordPress每篇内容添加二维码方法

如何为WordPress每篇内容添加二维码方法,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 现在二维码很火呀,微信扫码很火呀,为自己的博客每天文章都添加一个二维码功能岂不是很
2023-06-12

WordPress文章底部去除与添加版权信息的方法

本文实例讲述了WordPress文章底部去除与添加版权信息的方法。分享给大家供大家参考。具体分析如下: 这里参考一些网友的版权声明信息,具体更改LsJAtwzkgZ方法为: 外观>>编辑“single.php”文件,
2022-06-12

编程热搜

  • wordpress错位如何解决
    这篇文章主要介绍“wordpress错位如何解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“wordpress错位如何解决”文章能帮助大家解决问题。wordpress
    wordpress错位如何解决
  • 帝国cms调用栏目别名的修改步骤
    请留意下面的修改方法 修改后栏目别名使用 !--bname--] 调用 打开e/class/t_functions.php搜索定位到带模板的栏目导航标签修改1复制代码代码如下://替换变量$bclassname=$class_r[$clas
    帝国cms调用栏目别名的修改步骤
  • 动易Cms MAC验证视图失败的解决方法
    “/”应用程序中的服务器错误。 -------------------------------------------------------------------------------- 验证视图状态 MAC
    动易Cms  MAC验证视图失败的解决方法
  • DEDECMS如何支持中文水印
    DEDECMS如何支持中文水印?修改/include/inc_photograph.php,在165行处加这行代码:$w_text = iconv("GB2312","UTF-8",$w_text);OK,现在可以用中文做水印了,但默认的字体大小是5,中文字体
    DEDECMS如何支持中文水印
  • 快速了解Discuz!程序文件功能
    相信有不少人热衷于基于修改原有系统文件所做的插件,当然了解程序文件功能是最重要的,下面我把Discuz! X2.0主要的程序文件功能说一下。Tips:Q:针对说明的文件是?A:我只基于原版文件对upload目录中基本的程序文件(php,ht
    快速了解Discuz!程序文件功能
  • DedeCMS编辑器fck更换成eWebEditor编辑器具体步骤
    将eWebEditor编辑器插入DEDE后台的效果: 完全Word在线编辑的功能,让你从此摆脱发可编辑器卡得死,进入流畅干净编辑界面新时代。 下面是具体步骤: 首先,你要知道eWebEditor是一个什么工具。 eWebEditor是由国
    DedeCMS编辑器fck更换成eWebEditor编辑器具体步骤
  • 允许 WordPress 上传任意文件的方法
    此时如果上传一个不在预定义编程客栈的安全扩展名列表,如.lrc,会报kAtKhHRl错: F编程客栈ile type does not meet security guidelines. Try another. 解决此问题有两方法: 在
    允许 WordPress 上传任意文件的方法
  • dedecms 软件下载模块中添加下载方式为迅雷下载联盟代码
    修改 /plus/download.php 文件 www.cppcns.com查找
    dedecms 软件下载模块中添加下载方式为迅雷下载联盟代码
  • dedecms网站tag标签全部静态化的解决方法
    更改tags.php文件在根目录 找到$tag = FilterSearch(urldecode($tag)); 替换为:$tag = urldecode($tag); 更改文件arc.taglist.class.php文件文件所在的路径是
    dedecms网站tag标签全部静态化的解决方法
  • 帝国CMS远程保存图片的方法
    本文实例讲述了帝国cms远程保存图片的方法。分享给大家供大家参考。 具体实现方法如下:复制代码代码如下:
    帝国CMS远程保存图片的方法

目录