第一次在这里发帖;过去几天我已经花了很多时间而且我很接近而且卡住了。使用支持不佳的主题,可以很好地适应我们的所有自定义。它是一个企业目录网站。主题包括"精选"放置以更改格式并突出显示输出的列表。该主题还使用列表的自定义帖子类型。用户进入一个城市,州和主题返回尽可能多的列表在搜索范围内,我们正试图让在该半径内找到的任何特色列表成为结果的顶部,即使它不是&# 34;最接近&#34 ;.主题设定了"距离"使用以下代码在geo.php文件中:
static function posts_clauses( $clauses, $wp_query ) {
extract(appthemes_geo_get_args());
global $wpdb;
$geo_query = $wp_query->get( 'app_geo_query' );
if ( !$geo_query )
return $clauses;
extract( $geo_query, EXTR_SKIP );
$R = 'mi' == $unit ? 3959 : 6371;
$clauses['join'] .= $wpdb->prepare( " INNER JOIN (
SELECT post_id, ( %d * acos( cos( radians(%f) ) * cos( radians(lat) ) * cos( radians(lng) - radians(%f) ) + sin( radians(%f) ) * sin( radians(lat) ) ) ) AS distance FROM $wpdb->app_geodata
) as distances ON ($wpdb->posts.ID = distances.post_id)
", $R, $lat, $lng, $lat );
$clauses['where'] .= $wpdb->prepare( " AND distance < %f", (float) $rad );
if ( 'distance' == $wp_query->get( 'orderby' ) ) {
$clauses['orderby'] = 'distance ' . ( 'DESC' == strtoupper( $wp_query->get( 'order' ) ) ? 'DESC' : 'ASC' );
}
return $clauses;
}
}
然后在另一个文件(views.php)中,有一些参数可以按最高评分,按字母顺序排列,最新等方式更改排序顺序。我们遇到的问题是尝试将特色列表放在距离结果的顶部。有一个wp_query使用以下代码在顶部返回功能:
function parse_query( $wp_query ) {
global $va_options, $wpdb;
$wp_query->set( 'ls', trim( get_query_var( 'ls' ) ) );
$wp_query->set( 's', get_query_var( 'ls' ) );
$wp_query->set( 'post_type', VA_LISTING_PTYPE );
$wp_query->set( 'posts_per_page', $va_options->listings_per_page );
if ( '' == $wp_query->get( 'order' ) )
$wp_query->set( 'order', 'asc' );
$orderby = $wp_query->get( 'orderby' );
if ( empty( $orderby ) ) {
$location = trim( $wp_query->get( 'location' ) );
if ( !empty( $location ) ) {
$orderby = $va_options->default_geo_search_sort;
} else {
$orderby = $va_options->default_search_sort;
}
$wp_query->set( 'orderby', $orderby );
}
$wp_query->set( 'va_orderby', $orderby );
switch ( $orderby ) {
case 'default':
default:
$wp_query->set( 'meta_key', VA_ITEM_FEATURED );
$wp_query->set( 'orderby', 'meta_value_num' );
$wp_query->set( 'order', 'desc' );
$wp_query->set( 'va-featured', true );
break;
}
我删除了其他一些&#34;案例&#34;使代码更容易遵循。切换顺序中的默认距离如下所示:
case 'distance':
break;
这显然是因为orderby是在geo.php文件中定义的。我尝试添加$ wp_query-&gt; set(&#39; meta_key&#39;,&#39; featured_cat&#39;); (它是一个数字1或0,其中1为精选),然后为orderby添加一个数组,但它没有。
我认为答案是盯着我,但我希望得到一些帮助。任何帮助表示赞赏。
答案 0 :(得分:0)
想出来了。我注释掉了geo.php文件中的Orderby子句
if ( 'distance' == $wp_query->get( 'orderby' ) ) {
$clauses['orderby'] = 'distance ' . ( 'DESC' == strtoupper( $wp_query->get( 'order' ) ) ? 'DESC' : 'ASC' );
}
将orderby规则移动到views.php中。使用Wordpress 4.0,可以对orderbys进行精细控制。