wordpress自定义搜索

wordpress自定义搜索默认下,wordpress的搜索范围只有文章的标题和文章内容,无法搜索自定义字段中的内容,现实情况是很多情况下我们可能会要搜索自定义字段中的内容。如果只是想搜索一到两个自定义字段中的内容,可以使用wordpress的内置函数meta_query变量。12345678910111213141516171

大家好,又见面了,我是你们的朋友全栈君。

默认下,wordpress的搜索范围只有文章的标题和文章内容,无法搜索自定义字段中的内容,现实情况是很多情况下我们可能会要搜索自定义字段中的内容。

如果只是想搜索一到两个自定义字段中的内容,可以使用wordpress的内置函数 meta_query变量。

<!– 代码 –>

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

// Query arguments

$args = array(

    ‘post_type’ => ‘post’,

    ‘post_status’ => ‘publish’,

);

$args[‘meta_query’][] =array(

    ‘key’ => ‘city’,

    ‘value’ => $city,

    ‘compare’ => ‘LIKE’,

);

$args[‘meta_query’][] =array(

    ‘key’ => ‘state’,

    ‘value’ => $state,

    ‘compare’ => ‘LIKE’,

);

$query = new WP_Query($args );

if ( $query->have_posts() ):while ( $query->have_posts() ) :$query->the_post();

// Do loop here

endwhile; endif;

这个方法并不适合于搜索更多及至全部的自定义字段,因为如果你有很多个自定义字段,这上请求将会变得非常的庞大,wordpress执行起来也同样的要花很多时间。根据我的测试,10个自定义字段,就花了超过1分钟的时间还没有搜索得结果。

所以,我写了一个解决方案,不使用meta_query写复杂的请求,而是使用简单的SQL语句,查询出所有的必须的post_id,于是一切就直接了当了:

<!– 代码二 –>

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

global $wpdb;

// 如果你使用自定义搜索框

// $keyword = sanitize_text_field( $_POST[‘keyword’] );

//如果你使用wordpress默认搜索框

 

$keyword = get_search_query();

$keyword = “%{$keyword}%”;

// 搜索所有的自定义字段

$post_ids_meta = $wpdb->get_col($wpdb->prepare( “

    SELECT DISTINCT post_id FROM {
$wpdb->postmeta}

    WHERE meta_value LIKE ‘%s’

“, $keyword ) );

// 在文章标题或文章内容中搜索

$post_ids_post = $wpdb->get_col($wpdb->prepare( “

    SELECT DISTINCT ID FROM {
$wpdb->posts}

    WHERE post_title LIKE ‘%s’

    OR post_content LIKE ‘%s’

“, $keyword, $keyword ) );

$post_ids = array_merge($post_ids_meta, $post_ids_post );

// 查询参数

$args = array(

    ‘post_type’   => ‘post’,

    ‘post_status’ => ‘publish’,

    ‘post__in’    => $post_ids,

);

$query = new WP_Query($args );

if ( $query->have_posts() ):while ( $query->have_posts() ) :$query->the_post();

// Do loop here

endwhile; endif;

在上面的代码中,做了自定义搜索框的查询和wrodpress默认搜索框两种方式,可以根据需要注释掉其中一个。

上面的代码中,搜索了所有文章自定义字段,文章标题,文章内容,返回是符合的文章的ID组成的数组。然后再使用wp_query做了一个自定义查询,使用这个方法,可以很方便地使用模板标签把文章内容显示出来。

你可以把代码放到主题文章中的search.php文章中,去替换wordpress默认的搜索框。你也可以把这代码粘贴到一个自定义搜索框中。

参考资料:http://www.deluxeblogtips.com/2012/04/search-all-custom-fields.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/159159.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月14日 上午10:36
下一篇 2022年7月14日 上午10:36


相关推荐

  • flake8 vscode_vscode报错怎么看

    flake8 vscode_vscode报错怎么看在用vscode编译python时,自带的flake8报一些不必要的错误,解决办法:{“python.linting.pylintEnabled”:false,”python.linting.enabled”:true,”python.linting.flake8Enabled”:true,”python.linting.flake8Args”:[“–max-line-length=120″,”–ignore=E4

    2025年11月7日
    7
  • php curl get_python curl

    php curl get_python curl一条命令apt-getinstallphp-curl

    2022年8月30日
    9
  • dirsearch使用方法_查看es某个索引下的所有数据

    dirsearch使用方法_查看es某个索引下的所有数据下载地址:https://github.com/maurosoria/dirsearch要求安装并配置好:python3环境,python3环境,python3环境!!!使用方法,在cmd切换到安装目录pydirsearch.py-u网址-e语言(我一般用*)运行结果截图-u指定url-e指定网站语言例如pydirsearch.py-uwww.xxx.com…

    2022年10月6日
    3
  • 学生模式 在华为EMUI9.0上改成 健康使用手机背后的原因?

    学生模式 在华为EMUI9.0上改成 健康使用手机背后的原因?生活中,孩子用手机搜题、看剧、查资料、玩游戏很常见,监护人的合理引导是关键,EMUI9.0健康使用手机,是上一代【学生模式】的升级版。最大的区别是【学生模式】是让孩子在预设的时间段使用【健康使用手机】更注重于时间的平衡安排,限制手机或应用的可用时长通过合理引导加控制,让孩子健康享受科技的乐趣华为手机学生模式改成健康使用手机背后的原因?我想,EMUI9.0倡导的质享生活,就是管理好你的…

    2022年6月8日
    76
  • 讯飞星火X1升级版即将上线,深度推理能力再攀高峰

    讯飞星火X1升级版即将上线,深度推理能力再攀高峰

    2026年3月14日
    3
  • pycharm配置python开发环境

    pycharm配置python开发环境pycharm 的下载官网 https www jetbrains com pycharm 打开之后是这个样子的 下载下来是这个样子的文件 pycharm 的安装双击这个文件 进入安装界面点击 Next 接下就是什么都不要动 等待安装完毕安装成功之后是这个样子的此时桌面上就出现了 pycharm 的快捷方式 pycharm 的配置 python 开发环境 pycharm 的简单配置双击桌面上 pycharm 的快捷方式 打开 pycharm 打开之后是这个样子选择自己喜欢

    2026年3月27日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号