这是我第一次接触WordPress,我的任务是提取已定制的核心功能并将它们放在非核心文件中,以便在升级时更易于维护.这是wp-admin / includes / template.php中的一个方法的示例:
原始代码:
function meta_form() {
global $wpdb;
$limit = (int) apply_filters( 'postmeta_form_limit', 30 );
$keys = $wpdb->get_col( "
SELECT meta_key
FROM $wpdb->postmeta
GROUP BY meta_key
HAVING meta_key NOT LIKE '\_%'
ORDER BY meta_key
LIMIT $limit" );
if ( $keys )
natcasesort($keys);
?>
定制版本:
function meta_form() {
global $wpdb;
if ( isset($_GET['post']) )
$post_id = (int) $_GET['post'];
elseif ( isset($_POST['post_ID']) )
$post_id = (int) $_POST['post_ID'];
else
$post_id = 0;
if ( $post_id ) {
$post_ = get_post($post_id);
}
if ($post_->post_type == 'video_photo' ){
$limit = (int) apply_filters( 'postmeta_form_limit', 30 );
$keys = $wpdb->get_col( "
SELECT meta_key
FROM $wpdb->postmeta
where meta_key like 'tqmcf_%'
GROUP BY meta_key
HAVING meta_key NOT LIKE '\_%'
ORDER BY meta_key
LIMIT $limit" );
}else{
$limit = (int) apply_filters( 'postmeta_form_limit', 30 );
$keys = $wpdb->get_col( "
SELECT meta_key
FROM $wpdb->postmeta
GROUP BY meta_key
HAVING meta_key NOT LIKE '\_%'
ORDER BY meta_key
LIMIT $limit" );
}
if ( $keys )
natcasesort($keys);
?>
我究竟在哪里定义我的meta_form()函数以确保它覆盖核心方法?
解决方法:
在WordPress中,你无法改变整个核心.您有两种方法可以修改WordPress核心:
第一种选择:可插拔功能
某些功能可以重新定义.这可以在theme的functions.php文件或插件文件中完成.您可以查看Pluggable Functions的列表.
第二个选项:Filter和Action挂钩
> Filter hooks可用于修改核心内部的变量
WordPress流程.
> Action hooks可用于开火定制
对一些事件起作用.
注意1:您可以在主题或插件中创建自己的过滤器和动作挂钩.
注意2:如果找不到方便的动作挂钩,可以使用过滤钩来触发函数.
如果您遵循WordPress编码标准,您应该能够深入修改WordPress的行为.
对于你的显示功能,你应该寻找post_where过滤器钩子,做这样的事情:
add_filter( 'posts_where' , 'my_posts_where' );
function my_posts_where( $where ) {
global $post;
if ($post->post_type == 'video_photo' ){
$where .= " AND meta_key like 'tqmcf_%'";
}
return $where;
}
编辑1:即使此特定查询难以定位,以下内容可能更合适.
add_filter( 'query' , 'my_meta_form_query' );
function my_meta_form_query( $query ) {
$pattern = "/SELECT(?:\W*)meta_key(?:\W*)FROM (.*)(?:\W*.*?)*LIMIT(?:\W*)([0-9]*)/g";
if( preg_match($pattern, $query, $vars) ) {
$postmeta = $vars[1];
$limit = $vars[2];
$query = "SELECT meta_key
FROM $postmeta
WHERE meta_key like 'tqmcf_%'
GROUP BY meta_key
HAVING meta_key NOT LIKE '\_%'
ORDER BY meta_key
LIMIT $limit";
}
return $query;
}
您必须深入研究代码以找到合适的钩子以及如何最好地过滤变量.在此示例中,我们检查查询是否与meta_form()函数中的查询匹配.我们提取现有的查询变量,并构建一个包含WHERE条件的新查询.我没有测试这段代码,可能会有一些错误,但它可以让你知道我们如何改变核心代码.
原文地址:https://codeday.me/bug/20191006/1858353.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。