也想出现在这里? 联系我们

WordPress 5.5+ 可为元数据注册默认值

作者 : 小编 本文共1915个字,预计阅读时间需要5分钟 发布时间: 2020-08-7 共1.1K人阅读
也想出现在这里? 联系我们

WordPress 5.5 开始,register_meta() 函数(包括 register_post_meta())支持注册元数据默认值。在此之前,只能像这样注册REST API模式的默认值:

register_meta(

‘post’,

‘greeting’,

array(

‘single’ => true,

‘type’ => ‘string’,

‘show_in_rest’ => array(

‘schema’ => array(

‘type’ => ‘string’,

‘default’ => ‘hello’,

),

),

)

);

但是,这仅适用于从REST API内进行的调用 – 使用get_post_meta()将无法获取默认值。

WordPress 5.5 开始,可以传递一个默认值,该值将应用于任何元函数的所有调用,如下所示:

register_meta(

‘post’,

‘greeting’,

array(

‘single’ => true,

‘type’ => ‘string’,

‘default’ => ‘hello’,

‘show_in_rest’ => array(

‘schema’ => array(

‘type’ => ‘string’,

),

),

)

);

此次对register_meta()的改进,很像另一个函数register_setting(),自WordPress 4.7起,可以在register_setting()中注册选项的默认值。

默认值还可以与对象子类型(在WordPress 4.9.8中引入)配对,以限制默认值的范围。例如,如果插件注册的自定义文章类型为product。开发人员可以注册仅适用于product这个文章类型的默认值。如下所示:

register_post_meta(

‘product’,

‘price’,

array(

‘single’ => true,

‘type’ => ‘string’,

‘default’ => ‘0.00’,

)

);

值得注意的是,将默认值注册到这样的自定义文章类型可能会带来一些性能开销。要确定当前文章ID是哪种文章类型,它必须加载该对象。有关更多详细信息,请参见get_object_subtype。在大多数情况下,meta和主对象是同时加载的(例如使用WP_Query时),但是如果您的代码除了加载meta数据以外还执行其他操作,那么它现在也可以加载主对象类型。

非单一元数据

也可以注册非单一(Non-Single)的默认值,如下所示:

register_post_meta(

‘product’,

‘price’,

array(

‘single’ => false,

‘type’ => ‘string’,

‘default’ => ‘0.00’,

)

);

请求多个值时,如下所示:

$result = get_post_meta( 123, ‘price’, false );

上面的代码将返回一个以0.00作为第一个值的数字数组。

验证方式

注册默认元值时,数据必须与提供的类型匹配。以下示例将触发_doing_it_wrong通知提示hello不是整数(integer)。

register_meta(

‘post’,

‘greeting’,

array(

‘single’ => true,

‘type’ => ‘integer’,

‘default’ => ‘hello’,

)

);

新过滤器

如果您希望使用默认的元值进行一些真正的自定义,现在有一个过滤器:

$value = apply_filters( “default_{$meta_type}_metadata”, $value, $object_id, $meta_key, $single, $meta_type );

这是一个动态过滤器,要求您添加元类型。这是一个用法示例:

function add_my_meta_value( $value, $object_id, $meta_key, $single ){

if( ‘price’ === $meta_key ) {

if ( ! $single ) {

$value = array( ‘0.99’ );

} else {

$value = ‘0.99’;

}

}

}

add_filter( ‘default_post_metadata’, ‘add_my_meta_value’, 10, 4 );

新函数

为了使此功能成为可能,WordPress 核心添加了两个新函数:

get_metadata_raw()

get_metadata_default()

现在,get_metadata()函数调用get_metadata_raw(),如果该值为null,则调用get_metadata_default()。因此,调用get_metadata()不再获取原始值,这就是现在使用get_metadata_raw()的目的。

1. 本站所提供的源码模板(主题/插件)等资源仅供学习交流,若使用商业用途,请购买正版授权,否则产生的一切后果将由下载用户自行承担,有部分资源为网上收集或仿制而来,若模板侵犯了您的合法权益,请来信通知我们(Email: rayer@88.com),我们会及时删除,给您带来的不便,我们深表歉意!
2. 分享目的仅供大家学习和交流,请不要用于商业用途!
3. 如果你也有好源码或者教程,可以到用户中心发布投稿,分享有金币奖励和额外收入!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务 请大家谅解!
5. 如有链接无法下载、失效或广告,请联系站长,可领回失去的金币,并额外有奖!
6. 如遇到加密压缩包,默认解压密码为"www.zyfx8.cn",如遇到无法解压的请联系管理员!
本站部分文章、资源来自互联网,版权归原作者及网站所有,如果侵犯了您的权利,请及时联系我站删除。免责声明
资源分享吧 » WordPress 5.5+ 可为元数据注册默认值

常见问题FAQ

免费下载或者VIP会员专享资源能否直接商用?
本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
织梦模板使用说明
你下载的织梦模板并不包括DedeCMS使用授权,根据DedeCMS授权协议,除个人非盈利站点外,均需购买DedeCMS商业使用授权。购买地址: http://www.desdev.cn/service-dedecms.html

发表评论

Copyright 2015-2020 版权所有 资源分享吧 Rights Reserved. 蜀ICP备14022927号-1
开通VIP 享更多特权,建议使用QQ登录