【问题标题】:How to search by the title in wordpress WP_Query?如何在 wordpress WP_Query 中按标题搜索?
【发布时间】:2014-04-29 04:03:44
【问题描述】:

从wordpress官方文档网站,有一个搜索参数

http://codex.wordpress.org/Class_Reference/WP_Query#Search_Parameter

这是&s={keywords}

但是,我想知道这个搜索是否基于 Post 的所有内容?这意味着如果我提供 &s=book ,那么如果 Post 的 name = "abc" 是“book”的一个类别,它仍然包含在搜索结果中。有没有办法将搜索指定为仅 title_plain?

http://test.com/?json=get_posts&status=published&orderby=date&order=DESC&lang=en&s=eng&cat=9,10,14,15

感谢您的帮助。

【问题讨论】:

    标签: php html json wordpress


    【解决方案1】:

    你为什么要使用 wp_query 来搜索仅基于标题的帖子......当你在 wordpress 中有一个预先构建的功能时??

    Get Page By Title

    【讨论】:

    • 为了允许用户通过自定义表单搜索标题,...只是一个“基本”示例
    【解决方案2】:
    function __search_by_title_only( $search, &$wp_query )
    {
        global $wpdb;
        if ( empty( $search ) )
            return $search; // skip processing - no search term in query
        $q = $wp_query->query_vars;
        $n = ! empty( $q['exact'] ) ? '' : '%';
        $search =
        $searchand = '';
        foreach ( (array) $q['search_terms'] as $term ) {
            $term = esc_sql( like_escape( $term ) );
            $search .= "{$searchand}($wpdb->posts.post_title LIKE '{$n}{$term}{$n}')";
            $searchand = ' AND ';
        }
        if ( ! empty( $search ) ) {
            $search = " AND ({$search}) ";
            if ( ! is_user_logged_in() )
                $search .= " AND ($wpdb->posts.post_password = '') ";
        }
        return $search;
    }
    add_filter( 'posts_search', '__search_by_title_only', 500, 2 );
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2014-06-11
      • 1970-01-01
      • 2020-03-26
      • 1970-01-01
      • 1970-01-01
      • 2011-11-27
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多