arrays - Ajax DATA 更​​改排序

标签 arrays json ajax wordpress sorting

我正在使用我的 Wordpress 网站进行 AJAX 调用。除了来自 SUCCESS 函数的数据的 ORDER(排序)之外,它一切正常。

如果我print_r ($service) 我验证了我想要的正确自定义订单

但发送后使用:

(PHP 文件)

public function closest_services() {
    
    global $wpdb;
    
    $servicios_repetidos = $_POST['servicios_repetidos'];
    
    $lat        = $_POST['latitud'];
    $lng        = $_POST['longitud'];
    $categoria  = array();
    $unit       = $_POST['unit'];
    $distancia  = $_POST['radius'];
    
    if ( $unit == 'km' ) { $earth_radius = 6371.009 / 1.609344 ; }
    elseif ( $unit == 'mi' ) { $earth_radius = 3958.761; }
    
    $sql = $wpdb->prepare( "
        SELECT DISTINCT
            p.ID AS service_ID,
            p.post_title AS service_title,
            map_lat.meta_value AS locLat,
            map_lng.meta_value AS locLong,
            
            
            %f * 2 * ASIN(SQRT( POWER(SIN(( %f - map_lat.meta_value ) * pi()/180 / 2), 2) 
            + COS( %f * pi()/180) * COS( map_lng.meta_value * pi()/180) 
            * POWER(SIN(( %f - map_lng.meta_value) * pi()/180 / 2), 2) )) 
            AS distance
            
        FROM $wpdb->posts p
        INNER JOIN $wpdb->postmeta map_lat ON p.ID = map_lat.post_id
        INNER JOIN $wpdb->postmeta map_lng ON p.ID = map_lng.post_id
        WHERE 1 = 1
        AND p.post_type = 'servicios'
        AND p.post_status = 'publish'
        AND map_lat.meta_key = 'et_meta_latitud'
        AND map_lng.meta_key = 'et_meta_longitud'
        HAVING distance <= %d
        ORDER BY distance DESC",
        $earth_radius,
        $lat,
        $lat,
        $lng,
        $distancia      
    );
    
    $closest_services_query = $wpdb->get_results( $sql );
    $servicio = array();
    
    foreach ( $closest_services_query as $single_service ):
        
        $servicio[$single_service->service_ID]["service_ID"]            = $single_service->service_ID;
        $servicio[$single_service->service_ID]["meta_fields"]           = get_post_custom( $single_service->service_ID );
        $servicio[$single_service->service_ID]["service_author"]        = get_post_field ( 'post_author' , $single_service->service_ID );
        $servicio[$single_service->service_ID]["service_author_avatar"] = get_avatar( $single_service->service_ID , '64');
        $servicio[$single_service->service_ID]["service_author_url"]    = bp_core_get_user_domain( $single_service->service_ID );           
        $servicio[$single_service->service_ID]["category"]              = get_the_terms( $single_service->service_ID , 'servicios-categoria');
        $servicio[$single_service->service_ID]["service_title"]         = $single_service->service_title;
        
        $servicio[$single_service->service_ID]["thumb_url"]             = wp_get_attachment_image_src( get_post_thumbnail_id( $single_service->service_ID ) , 'medium' );
      
        $servicio[$single_service->service_ID]["distancia"]             = $single_service->distance;
        
        $servicio[$single_service->service_ID]["precio_servicio_visibilidad"] = get_post_meta( $single_service->service_ID , 'et_meta_precio_visibilidad' , true);
        
        if ( function_exists( 'get_favorites_button' ) ) 
            $servicio[$single_service->service_ID]["favorite_button"] = get_favorites_button( $single_service->service_ID );

    endforeach;
    
    //print_r($servicio);
    wp_send_json($servicio);
    
}

(JQUERY 文件)

function ajax_mapa () {                 
    var center = map.getCenter();
        
    latitud     = center.lat();
    longitud    = center.lng();
    
    jQuery( "body" ).after( "<div class='loading'>Loading&#8230;</div>" );
                                                
    jQuery.ajax({
        url: ajax_object.ajax_url,
        type: "POST",
        dataType: "JSON",
        
        data: { 
            'action'    : 'closest_services',
            'latitud'   : latitud,
            'longitud'  : longitud,
            'categoria' : categoria,
            'servicios_repetidos' : servicios_repetidos,
            'unit'      : 'km',
            'radius'    : 15
        },      
         
        success: function( data, textStatus, jqXHR ) { // Si todo salio bien se ejecuta esto
            
            console.log(data);
            console.log(textStatus);
            console.log(jqXHR);
            
            var servicios = [];
            var precio;
            var moneda;
            var url_imangen;
            var html_marker;
            
            
            
            jQuery.each( data, function( id_servicio, info_servicio ) { ... ...});
     } ... ...
     ...
 }) ...
   } ...

DATA 的 LOG 显示按 KEY VALUE 排序的对象,而不是之前发送的自定义顺序。

如果我从 jqXHR.responseText 检查日志,它有我想要的正确顺序,所以基本上数据接收正常,但有些东西正在改变顺序。

所以,问题是,有人知道为什么 DATA 按 KEY VALUE 排序吗?我该如何解决这个问题?

(具有正确顺序的 jqXHR 日志 - 按距离)

"{"144":

{"service_ID":"144","distancia":"6.043960511486238"},"110":{"service_ID":"110","distancia":"6.040024571156195"},"112":{"service_ID":"112","distancia":"6.040024571156195"},"113":{"service_ID":"113","distancia":"6.040024571156195"},"114":{"service_ID":"114","distancia":"6.040024571156195"},"119":{"service_ID":"119","distancia":"6.040024571156195"},"145":{"service_ID":"145","distancia":"6.040024571156195"},"194":{"service_ID":"194","distancia":"5.025501693483518"},"163":{"service_ID":"163","distancia":"4.985331564912346"},"161":{"service_ID":"161","distancia":"1.3274942401635288"}}"

(顺序不正确的数据日志 - 按 key ID)

Object { 110: Object, 112: Object, 113: Object, 114: Object, 119: Object, 144: Object, 145: Object, 161: Object, 163: Object, 194: Object }

谢谢

最佳答案

不确定这是否是最佳解决方案,但我设法通过将 OBJECT 转换为数组然后对数组进行排序来使其工作。

基本上我添加了这段代码:

/* ********************** */
// ordeno por distancia
/* ********************** */
var arr = jQuery.map(data, function(value, key){
    return value
});

function SortByName(a, b){
    var aName = a.distancia;
    var bName = b.distancia; 

    return ((aName > bName) ? -1 : ((aName < bName) ? 1 : 0));
}

arr.sort(SortByName);
/* ********************** */

就在 de jQuery.each( arr , function( id_servicio, info_servicio ) { ... ...}); 函数之前

关于arrays - Ajax DATA 更​​改排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45363926/

相关文章:

PHP/MYSQL 到 SESSION - 做什么

android - 滚动时 ListView 图像发生变化

javascript - 在js文件中包含jquery

javascript - Rails 4/jQuery : Need entry of value in a form input to autofill other inputs

ios - UIPickers 数据不会从 UITextField 显示

javascript - 使用动态字符串名称引用数组

java - 我正在比较来自 2 个独立数组的 2 组整数值

jquery - 如何对记录集进行分页

javascript - mustache 模板不在表 tbody 内呈现

javascript - 我无法将 FormData 发送到 php