jQuery if()工作不好要求空的ajax响应

时间:2012-01-18 19:36:38

标签: php javascript jquery null stock

我有一个表格,我根据用户的选择加载部分。

当用户选择日期时,我会在该日期搜索可用股票的qtty(这是火车旅行中的座位)。

我有3个IF()个句子

  • 首先,我询问db响应是否没有返回任何行(因此该日期的旅行尚未创建,所以我必须在那个时刻创建它以供客户保留)
  • 其次,我问响应是否是一个数字(我只返回一个数字,对不起,如果我之前没有指定)并且它是否大于零。所以我更新了可用的qtty。因此,顾客不能过度购买不存在的座位。
  • 第三个也是最后一个,如果其他人失败并且qtty为零,我只是向客户发送一条消息,表明该日期的旅行已满,他/她必须选择一个不同的旅行日期。

我的代码是:

$.post(url,function(data){
        //********************
        //data = parseInt(data);
        alert("muestra: "+data+".");
            //3 opciones
        //si viene vacia la respuesta, es por que no encontro, reservas  o sea que nadie a reservado para la fecha solicitada
        //     lo que sigue es crear la reserva de todas formas, luego re-consultar por los valores y traer la cantidad total //podria mejorar
        //si viene con 0 es por que no existe disponibilidad para el viaje en esa fecha, tendra que intentar cambiando categoria (vagon) o fecha
        //si un numero >=1 hay disponibilidad y se crean los sliders que le permiten seleccionar la cantidad de asientos para reservar
        //TODO: cambiar al switch ....
        if(data=="false" || data==false){
        //if(data=='NaN'){
            $("#info-disponibilidad").html("No existen reservas previas, sera el primero en reservar para esta fecha. Asientos Disponibles: ");
            $("#info-disponibilidad").css("color","green");
            var myRandom=parseInt(Math.random()*99999999);  // tecnica cache buster
            //url = 'asientos-disponibilidad.php?categoria='+$('#categoria option:selected').val()+'&fecha_reserva='+$('#fecha_reserva').val()+'&rand=' + myRandom;
            url = 'crear_reservas.php?viaje='+$('#viajes option:selected').val()+'categoria='+$('#categoria option:selected').val()+'&fecha_reserva='+dateText+'&rand=' + myRandom;
            $.post(url,function(data2){
                //algo algo con la respuesta... ...
                alert("1er: "+data2+".");
            });
        }

        if(!isNaN(data) && data!=0){
        //if(!isNaN(data) && data!=0){
            alert("2do: "+data);
            //este se puede aprender facilmente al buscar el ejemplo en Jquery Ui slider
            $("#info-disponibilidad").html("Existen, "+data+" asientos Disponibles");
            $("#info-disponibilidad").css("color","green");
            //este se puede aprender facilmente al buscar el ejemplo en Jquery Ui slider
            $( "#slider-adultos" ).slider({
            //range: "min",
            min: 1,
            max: data,
            slide: function( event, ui ) {
                $( "#adultos" ).val(ui.value );
                $("#adultos").trigger("change");
            },
            stop: function(event, ui) { 
                $("#total-box").effect("highlight", {}, 2000);  
                //var max = parseInt($("#adultos").val());//usar esta variable en lugar de value (por si algo falla)
                manejoreservas(ui.value,"ninos", data);
            }
            });
            $("#slider-ninos").slider({
            //range: "min",
            min: 0,
            max: data,
            slide: function( event, ui ) {
                $( "#ninos" ).val(ui.value );
                $( "#ninos" ).trigger("change");
            },
            stop: function(event, ui) {
                $("#total-box").effect("highlight", {}, 2000);
                //$("#slider-ninos").slider( "option", "max", max );
                //var max = parseInt($("#ninos").val());//
                manejoreservas(ui.value,"adultos", data);
            }
            });
        }
        else//(!isNaN(data) && data==0  && data!=false)
        {   // && data!=false
            alert("3ro: "+data+" no disponibilidad");
            $("#info-disponibilidad").html("No existen asientos Disponibles");
            $("#info-disponibilidad").css("color","red");
        }
        });

和php代码是这样的:

<?php
//busca cual es la cantidad de asientos disponibles en una reserva si es que esta existe...
include('conn.php');
if (!$con)
  {
    die('Fallo conexion a la Base de datos: ' . mysql_error());
  }else{
  $categoria = $_GET['categoria'];
  //$fecha = $_POST['fecha_reserva'];
  $fecha = $_GET['fecha_reserva'];

  $sql_cant ="SELECT restante FROM reservas WHERE fecha_reserva = '".$fecha."' AND categorias_idcategorias = ".$categoria."";

  mysql_select_db("mvargas", $con);

  $result = mysql_query($sql_cant);
  $num_rows = mysql_num_rows($result);
  //echo $sql_cant;
  if($num_rows < 0){
    echo "";
  }else{


    //echo "<b>".$num_rows."</b>";
    while($row = mysql_fetch_assoc($result)){
      $foo = $row['restante'];
      $j++;
    }  
    //
    //var_dump($foo);
    echo $foo;
  }
}
?>

我取得的最后一件事就是一切正常,但它进入第一个IF,显示一条消息,用户将在该日期首次预订(创建旅行)然后进入第三个{ {1}}(否则在显示的代码中)删除第一条消息,并为零qtty设置消息,在屏幕上闪烁两条消息,以免造成用户混淆。

很抱歉,如果时间太长了...这是您要查看的页面:http://www.micontrol.cl/~mvargas/wordpress/wp-transatacama/reservas-rapidas/form-reservas.php

2 个答案:

答案 0 :(得分:2)

如果我理解正确的话,请将第2个if改为其他,如果......

....
....
            alert("1er: "+data2+".");
        });
    } else if(!isNaN(data) && data!=0){
    //if(!isNaN(data) && data!=0){
        alert("2do: "+data);
....
....

如果第一个if语句不成立,它将只运行第二个if语句。

答案 1 :(得分:0)

我假设你指的是data变量返回0或空白。在javascript中,语句0 == false的计算结果为true。您需要使用所谓的严格比较,例如0 === false,其评估为false。

所以更新你的代码:

if(data=="false" || data===false){

除非您有特殊原因,否则始终使用严格的比较运算符是个好主意。它们是===!==

请注意,以下语句评估为true

(false == 0); // true  
(false == ""); // true