gpt4 book ai didi

arrays - Ajax DATA 更​​改排序

转载 作者:行者123 更新时间:2023-12-05 07:41:22 24 4
gpt4 key购买 nike

我正在使用我的 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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com