Во-первых, удалите несогласованность имен переменных. НЕ СМЕШАЙТЕ ПЕРЕМЕННОЕ НАЗВАНИЕ, КАК ВЫ СДЕЛАЛИ, У ВАС ЕСТЬ ОДИН, КОТОРЫЙ НАЧИНАЕТ КАПИТАЛ И ОДИН, КОТОРЫЙ НЕ СУЩЕСТВУЕТ! Это подвержено ошибкам.
Я рефакторил ваш php для всех переменных нижнего регистраи верните json - так что он будет дружественным к JavaScript:
PHP:
if(isset($request))
{
$marque = $request->get('marque');
$modele = $request->get('modele');
$finition = $request->get('finition');
$Debut = $request->get('debut');
$Fin =$request ->get('fin');
$TotalAproduire = 100;
$Commande = DB::connection('sqlsrv2')->table('Commande_nadine')
->join('finition','Commande_nadine.CodeFinition','=','finition.CodeFinition')
->where('finition.CodeFinition',"=",$finition)
->where('finition.CodeModele','=',$modele)
->where('Commande_nadine.DATE_DOCUMENT_CMD_ACHAT_FRS',">",$debut)
->whereDate('Commande_nadine.DATE_DOCUMENT_CMD_ACHAT_FRS',"<",$fin)
->whereDate('finition.CodeMarque','=',$marque)
->count('Commande_nadine.RECID_NADIN');
$PourcentageCommandee=($Commande/$TotalAproduire)*1000;
return response()->json($PourcentageCommandee);
}
else
{ //return error response with 500 code
response()->json("failed", 500);
}
Вместо того, чтобы отправлять ваши данные в URL-адресе как запрос, введитеdata
собственность.Он будет отправлен как данные тела.Пожалуйста, также console.log(data);
перед Ajax, чтобы убедиться, что он имеет правильные значения.Я также предоставил объяснение в коде, это само собой понятно, я надеюсь.
JS:
var periode=$("#Période").val();
var DebutFin = periode.split(' - ');
var Debut = DebutFin[0];
var Fin = DebutFin[1];
var marque = $("#CodeMarque").val();
var modele = $("#CodeModele").val();
var finition = $("#CodeFinition").val();
const data = {debut, fin, marque, modele, finition};
// check if the output is correct! Illegal operator error means you may have done
// an operation that cannot be done to the datatype. E.g. multiplication, division etc
// on a non number datatype
console.log(data);
$.ajax({
url:"home/Calculer", //remove that ugly URL an pass it as data body instead
method:"GET",
data: data, //data body
cache : false,
datatype: "JSON",
processData: false,
success: function(result)
{
console.log(result);
$("#CommandePasses").data('easyPieChart').update(result);
$('span', $("#CommandePasses")).text(result);
},
error: function(err) {
console.log(err);
}
});