douxian3170 2016-06-03 21:36
浏览 59
已采纳

将数组从查询字符串添加到WP meta_query

I am collecting values from a query string as an array. Then collecting those values and placing them into the value of the 'meta_query'.

I am having trouble where nothing gets outputted from the WP_Query. I feel like there is something wrong with the second array in the 'meta_query'.

I have tried to change the compare to 'LIKE', and that shows all the content instead of what is in the query.

Query string:

?variable[]=value1&variable[]=value2

PHP code:

<?php
$variable_selected = $_GET['variable'];

$filter = array(
    'post_type' => 'my_custom_post_type',
    'meta_query' => array(
        'relation' => 'OR',
         array(
            'key' => 'my_post_field',
            'value' => $variable_selected,
            'compare' => 'IN'
            )
        )

    );

    $posts = new WP_Query( $filter  );

Any help on this will be great.

  • 写回答

2条回答 默认 最新

  • douxidao3524 2016-06-06 12:35
    关注

    This makes the meta_query dynamic depending on how many values are in the query string.

    $meta_query = array();
    if ( ! empty( $_GET["variable"] ) ) {
        if ( is_array( $_GET["variable"] ) ) {
            $meta_query['relation'] = 'OR';
            foreach ( $_GET["variable"] as $value ) {
                $meta_query[] = array(
                    'key' => 'my_post_field',
                    'value' => sanitize_text_field( (string) $value ),
                    'compare' => 'LIKE'
                );
            }
        } else {
           $meta_query = array(
                'key' => 'my_post_field',
                'value' => sanitize_text_field( (string) $_GET["variable"] ),
                'compare' => '='
           );
        }
     }
     $filter = array(
        'post_type' => 'my_custom_post_type',
        'meta_query' => array(
           'relation' => 'OR',
           $meta_query
     )
     );
     $posts = new WP_Query( $filter );
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
  • douxingti9307 2016-06-04 06:48
    关注

    I would first run a var_dump on $variable_selected to make sure you are getting the array that you need. Also, since you are just using one meta key/value field, you might not need the OR in your query, so you could do something like below. Hope that helps.

    <?php
    $variable_selected = $_GET['variable'];
    
    // Use the var_dump to test to see if array is being pulled in properly.
    var_dump ( $variable_selected );    
    
    $filter = array(
    'post_type' => 'my_custom_post_type',
    'meta_query' => array(
         array(
            'key' => 'my_post_field',
            'value' => $variable_selected,
            'compare' => 'IN'
            )
        )
    
    );
    
    $posts = new WP_Query( $filter  );
    
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 linux tsi721的驱动编译后 insmod 提示 报错
  • ¥20 multisim测数据
  • ¥15 求无向连通网的所有不同构的最小生成树
  • ¥15 模拟器的framebuffer问题
  • ¥15 opencv检测轮廓问题
  • ¥15 单点式登录SSO怎么爬虫获取动态SSO_AUTH_ACCESS_Token
  • ¥15 在app设计的坐标区绘图,如何选定绘图范围
  • ¥30 哈夫曼编码译码器打印树形项目
  • ¥20 求完整顺利登陆QQ邮箱的python代码
  • ¥15 怎么下载MySQL,怎么卸干净原来的MySQL