WordPress 创建自定义字段面板

但是对于自定义字段的时候,在后台添加的使用通过那个面板添加十分不方便,比如你要使用自定义字段来实现seo功能,那么你每次都需要重复输入字段名称:title\keywords\description。

今天这篇文章,我们将讲解为自定义字段添加一个固定的面板,这样就不用每次为每个字段输入字段名称了。

说明:不要误以为自定义面板就是用来添加自定义字段的,你可以通过本篇教程添加一个自定义字段来干任何事,比如你只是想显示一个提示信息而已,用来显示浏览次数,等等。。。本篇教程的核心应该是怎样在后台添加自定义面板。

效果图:

WordPress 创建自定义字段面板

要在后台创建一个面板,首先了解一个函数:

<?php
add_meta_box( $id, $title, $callback, $post_type, $context, $priority, $callback_args );
//$id--面板的的id属性(html)。
//$title--面板标题
//$callback--调用的函数
//$post_type--要在编辑页面创建面板的文章类型,比如post\page..自定义的文章类型等
//$context--(可选)面板要显示的位置,可以使用normal\advanced\side分别为普通、高级(貌似跟普通效果差不多)、边栏
//$priority--(可选)显示的优先级,可以使用high\core\default\low 如果设置为high那么它会显示在默认的那些自定义字段、评论、作者什么的前面
//$callback_args--(可选、数组)要传给那个$callback函数的参数
?>

准备工作:

准备文件,作者以默认的twenty ten主题做测试,在默认主题中新建一个metabox.php文件,而后在主题的functions.php中include该文件。

include 'metabox.php';

步骤、(接下来的代码参考自露兜博客)

一、准备要创建的字段信息

我们将添加keywords和description两个字段。在metabox.php文件中添加代码(php文件别忘了<?php 和?>哦):

$new_meta_boxes =
array(
"description" => array(
"name" => "description",
"std" => "这里填默认的网页描述",
"title" => "网页描述:"),
"keywords" => array(
"name" => "keywords",
"std" => "这里填默认的网页关键字",
"title" => "关键字:")
);

这是一个二维数组,数组的第一个元素就是description字段的信息,包括标题、字段名、描述信息。

二、创建(显示)面板内容的函数

function new_meta_boxes() {
global $post, $new_meta_boxes;
foreach($new_meta_boxes as $meta_box) {
$meta_box_value = get_post_meta($post->ID, $meta_box['name'].'_value', true);
if($meta_box_value == "")
$meta_box_value = $meta_box['std'];
echo'<input type="hidden" name="'.$meta_box['name'].'_noncename" id="'.$meta_box['name'].'_noncename" value="'.wp_create_nonce( plugin_basename(__FILE__) ).'" />';
// 自定义字段标题
echo'<h4>'.$meta_box['title'].'</h4>';
// 自定义字段输入框
echo '<textarea cols="60" rows="3" name="'.$meta_box['name'].'_value">'.$meta_box_value.'</textarea><br />';
}
}

该函数用来显示面板的内容,将作为add_meta_box函数才callback参数调用。

三、创建面板

function create_meta_box() {
global $theme_name;
if ( function_exists('add_meta_box') ) {
add_meta_box( 'new-meta-boxes', '自定义模块', 'new_meta_boxes', 'post', 'normal', 'high' );
}
}

这个函数代码就不解释了,看前面函数详细介绍。

四、保存更新数据

function save_postdata( $post_id ) {
global $post, $new_meta_boxes;
foreach($new_meta_boxes as $meta_box) {
if ( !wp_verify_nonce( $_POST[$meta_box['name'].'_noncename'], plugin_basename(__FILE__) )) {
return $post_id;
}
if ( 'page' == $_POST['post_type'] ) {
if ( !current_user_can( 'edit_page', $post_id ))
return $post_id;
}
else {
if ( !current_user_can( 'edit_post', $post_id ))
return $post_id;
}
$data = $_POST[$meta_box['name'].'_value'];
if(get_post_meta($post_id, $meta_box['name'].'_value') == "")
add_post_meta($post_id, $meta_box['name'].'_value', $data, true);
elseif($data != get_post_meta($post_id, $meta_box['name'].'_value', true))
update_post_meta($post_id, $meta_box['name'].'_value', $data);
elseif($data == "")
delete_post_meta($post_id, $meta_box['name'].'_value', get_post_meta($post_id, $meta_box['name'].'_value', true));
}
}

改函数用来保存和更新我们的字段值

五、触发函数

OK,函数代码都准备好了,下马就是触发了,我们应该先执行create_meta_box函数,因为 add_meta_box是由它调用的。使用动作钩子,继续添加下面的代码:

add_action('admin_menu', 'create_meta_box');
add_action('save_post', 'save_postdata');

同时在保存文章的时候执行更新和保存字段的函数。

六、调用函数

调用:通过 get_post_meta函数调用即可

$description = get_post_meta($post->ID, "description_value", true);
$keywords = get_post_meta($post->ID, "keywords_value", true);

注意字段名称,我们在保存数据的时候,保存的字段名称分别是description_value、keywords_value。。。

OK,自定义面板的创建结束。


 上一篇
 WordPress 不同分类显示不同内容(广告)		WordPress 不同分类显示不同内容(广告)
WordPress 不同分类显示不同内容(广告),比如多本小说站,一般一个分类为一本小说,为了了解每一本小说的收入效果,需要为不同的分类(小说)添加不同的广告,这个不同的广告不一定是格式大小不同,而是广告代号不同。 和WordPress判断
2018-03-12
下一篇 
 如何给WordPress网站添加欢迎引导页		如何给WordPress网站添加欢迎引导页
由于WordPress的博客出身,许多WordPress网站主题看起来像是个单纯的博客。很多用户想要给自己的网站添加一个欢迎引导页面,将WordPress博客改造成CMS网站,或者将最重要的内容推荐给网站访问者。今天就给大家介绍一下,如何给
2018-03-11
  目录