WordPress中编写自定义存储字段的相关PHP函数解析
2015-12-25 00:00
639 查看
WordPress 的自定义字段就是文章的 meta 信息(元信息),利用这个功能,可以扩展文章的功能,是学习 WordPress 插件开发和主题深度开发的必备知识,方便给文章储存一些额外的自定义内容。
自定义字段不光给插件开发者使用,WordPress 的特色图像、自定义页面模板等功能的信息都储存在自定义字段的表单里边。
在文章编辑器界面的 “自定义栏目” 板块可以管理除了名字开头是 “_” 的字段(没有 “自定义栏目” 板块请在右上角的 “显示选项” 开启),所以很多 WordPress 自己使用的自定义字段无法在此管理。
存储原理
自定义字段非常灵活,首先来说一下它的储存原理和为什么这么灵活。数据库中,储存文章的 wp_posts 表单,只有默认的 20 个项目,用于储存必须的文章信息。
而存储自定义字段的 wp_postmeta 表,却只有四个项目,分别是 meta_id(自定义字段的 ID)、post_id(自定义字段属于的文章的 ID)、meta_key(自定义字段的名字)和 meta_value(自定义字段的值),一般我们只需要注意 meta_key 和 meta_value 两个项目即可。
正是因为这样,每篇文章都可以有相同名字但不同值的自定义字段,而且可以有无限个自定义字段,任何的插件和主题都可以利用自定义字段对文章信息进行扩展。
一篇文章的自定义字段的名字是可以重复的。
添加字段
自定义字段可以在文章编辑页面操作,但本文主要写关于开发的事情。
添加自定义字段,可以使用 add_post_meta() 函数:
参数:
$post_id
(整数)(必须)添加自定义字段的文章的 ID.
默认值:None
$meta_key
(字符串)(必须)自定义字段的名称。
默认值:None
$meta_value
(混合)(必须)自定义字段的值。
默认值:None
$unique
(布尔)(可选)如果已经有相同名字的字段,是否重复添加。True 允许;False 不允许。
默认值:False
更新字段
要更新一个字段的值,可以使用 update_post_meta() 函数:
参数:
$post_id
(整数)(必须)更新自定义字段的文章的 ID.
默认值:None
$meta_key
(字符串)(必须)更新的自定义字段的名称。
默认值:None
$meta_value
(混合)(必须)更新的自定义字段的值。
默认值:None
$prev_value
(混合)(可选)此参数只有在一篇文章有多个相同名称的自定义字段时才有用。如果留空,则更新所有同名的字段,否则则更新和此参数值相同的值的字段。
默认值:空字符串
获取字段
获取字段可以使用 get_post_meta() 函数:
参数:
$post_id
(整数)(必须)要获取字段的文章 ID,如果在循环中,可以使用 get_the_ID() 来设置。
默认值:None
$key
(字符串)(可选)要获取的字段的名称。
默认值:None
$single
(布尔)(可选)如果为 True 则返回一个字符串;如果为 False 则返回数组,且相同键值的自定义字段的值会按照添加顺序组合成一个序列数组。
默认值:False
例子
下边是一个浏览统计的简单例子:
获取计数:
不可见的自定义字段
虽然在数据库里存在很多 WordPress 自己创建的自定义字段,但是在文章编辑器的 “自定义栏目” 里却并没有显示(没有 “自定义栏目” 板块请在右上角的 “显示选项” 开启),比如特色图像、自定义页面模板和评论是否开启等等。
如果仔细观察,会发现这些自定义字段的名字都是以下划线 “_” 开头的,所以说,以下划线 “_” 开头的自定义字段并不会显示给用户,the_meta() 函数也不会输出,对用户来说是隐藏的。
利用这个特性,我们可以把不想让用户随便修改的字段、会让用户感到困惑的字段,比如已经提供设置界面的设置选项、缓存数据等等,以免出现错误。
下边是一个小例子:
另外,如果自定义字段储存的内容是数组即使名字前边不是下划线 “_” 也不会显示。
详解WordPress中调用评论模板和循环输出评论的PHP函数
详解WordPress中创建和添加过滤器的相关PHP函数
详解WordPress开发中get_current_screen()函数的使用
自定义字段不光给插件开发者使用,WordPress 的特色图像、自定义页面模板等功能的信息都储存在自定义字段的表单里边。
在文章编辑器界面的 “自定义栏目” 板块可以管理除了名字开头是 “_” 的字段(没有 “自定义栏目” 板块请在右上角的 “显示选项” 开启),所以很多 WordPress 自己使用的自定义字段无法在此管理。
存储原理
自定义字段非常灵活,首先来说一下它的储存原理和为什么这么灵活。数据库中,储存文章的 wp_posts 表单,只有默认的 20 个项目,用于储存必须的文章信息。
而存储自定义字段的 wp_postmeta 表,却只有四个项目,分别是 meta_id(自定义字段的 ID)、post_id(自定义字段属于的文章的 ID)、meta_key(自定义字段的名字)和 meta_value(自定义字段的值),一般我们只需要注意 meta_key 和 meta_value 两个项目即可。
正是因为这样,每篇文章都可以有相同名字但不同值的自定义字段,而且可以有无限个自定义字段,任何的插件和主题都可以利用自定义字段对文章信息进行扩展。
一篇文章的自定义字段的名字是可以重复的。
添加字段
自定义字段可以在文章编辑页面操作,但本文主要写关于开发的事情。
添加自定义字段,可以使用 add_post_meta() 函数:
add_post_meta( $post_id, $meta_key, $meta_value, $unique );
参数:
$post_id
(整数)(必须)添加自定义字段的文章的 ID.
默认值:None
$meta_key
(字符串)(必须)自定义字段的名称。
默认值:None
$meta_value
(混合)(必须)自定义字段的值。
默认值:None
$unique
(布尔)(可选)如果已经有相同名字的字段,是否重复添加。True 允许;False 不允许。
默认值:False
更新字段
要更新一个字段的值,可以使用 update_post_meta() 函数:
update_post_meta( $post_id, $meta_key, $meta_value, $prev_value );
参数:
$post_id
(整数)(必须)更新自定义字段的文章的 ID.
默认值:None
$meta_key
(字符串)(必须)更新的自定义字段的名称。
默认值:None
$meta_value
(混合)(必须)更新的自定义字段的值。
默认值:None
$prev_value
(混合)(可选)此参数只有在一篇文章有多个相同名称的自定义字段时才有用。如果留空,则更新所有同名的字段,否则则更新和此参数值相同的值的字段。
默认值:空字符串
获取字段
获取字段可以使用 get_post_meta() 函数:
get_post_meta( $post_id, $key, $single );
参数:
$post_id
(整数)(必须)要获取字段的文章 ID,如果在循环中,可以使用 get_the_ID() 来设置。
默认值:None
$key
(字符串)(可选)要获取的字段的名称。
默认值:None
$single
(布尔)(可选)如果为 True 则返回一个字符串;如果为 False 则返回数组,且相同键值的自定义字段的值会按照添加顺序组合成一个序列数组。
默认值:False
例子
下边是一个浏览统计的简单例子:
function Bing_statistics_visitors( $cache = false ){ if( !is_singular() ) return; global $post; $id = $post->ID; if( get_post( $id )->post_status != 'publish' ) return; $post_views = (int) get_post_meta( $id, 'views', true ); update_post_meta( $id, 'views', ( $post_views + 1 ) ) || add_post_meta( $id, 'views', 1, true ); } add_action( 'wp_head', 'Bing_statistics_visitors' );
获取计数:
function Bing_get_views(){ global $post; $views = number_format( (int) get_post_meta( $post->ID, 'views', true ) ); return $views; }
不可见的自定义字段
虽然在数据库里存在很多 WordPress 自己创建的自定义字段,但是在文章编辑器的 “自定义栏目” 里却并没有显示(没有 “自定义栏目” 板块请在右上角的 “显示选项” 开启),比如特色图像、自定义页面模板和评论是否开启等等。
如果仔细观察,会发现这些自定义字段的名字都是以下划线 “_” 开头的,所以说,以下划线 “_” 开头的自定义字段并不会显示给用户,the_meta() 函数也不会输出,对用户来说是隐藏的。
利用这个特性,我们可以把不想让用户随便修改的字段、会让用户感到困惑的字段,比如已经提供设置界面的设置选项、缓存数据等等,以免出现错误。
下边是一个小例子:
add_post_meta( get_the_ID(), '_time_diff', time() );
另外,如果自定义字段储存的内容是数组即使名字前边不是下划线 “_” 也不会显示。
您可能感兴趣的文章:
WordPress中调试缩略图的相关PHP函数使用解析详解WordPress中调用评论模板和循环输出评论的PHP函数
详解WordPress中创建和添加过滤器的相关PHP函数
详解WordPress开发中get_current_screen()函数的使用
相关文章推荐
- WordPress中创建用户角色的相关PHP函数使用详解
- PHP版本升级到7.x后wordpress的一些修改及wordpress技巧
- PHP获取二维数组中某一列的值集合
- PHP-MD5加密研究
- php soket模拟提交文件上传域(多个)
- zend studio 12.5
- zend studio 编程风格
- matplotlib
- yii2项目前台页面开发中,用到的算法1 (例题解析)
- weiphp转移项目后,验证码不显示问题
- TP-LINK路由器连接网线上网教程(租房必备)
- php -- php模拟浏览器访问网址
- Exception 'yii\db\Exception' with message 'SQLSTATE[HY000] [2002] No such file or directory’错误的解决方法
- php命名空间
- Wireshark提取RTP包中的H264码流
- PHP - 发送短信
- PHP编译参数详解
- PHP的ArrayAccess接口简介
- CCNP学习笔记14-交换部分---STP
- thinkphp里的session、cookie方法