只需要工作一次,就可以使用Ajax的PHP

时间:2014-09-21 05:25:22

标签: javascript php jquery mysql ajax

我试图开始工作的代码是数据库产品价格表的一部分。它几乎所有的工作但我需要一个ajax运行多次,它确实,它甚至运行成功的句子,但当我检查数据库它就像它只运行一次...我希望你能帮助我。

我从输入中获取2个值,这些值是产品的id和数量,当按钮调用send函数时,我将它们添加到列表中,这是代码的一部分:

function valores(cod, cant) {

if (cod != '') {
    cot.push([cod, cant]);
    i++;
}
return cot;
}

function send () {

event.returnValue=false; 

var id = $('#id').val();
var amount = $('#cant').val();
var total;


    if ($('#total').length > 0) {
        total = document.getElementById('total').value;
    } else {
        total = 0;
    }

    $.ajax({
        type: 'POST',
        data: ({cod : id, cant : amount, tot : total }),
        url: 'process/agprods.php',
        success: function(data) {
            $('#totals').remove();
            $('#prodsadded').append(data);
            valores(id, amount);
            rs = $(document.getElementById('rs').html);
        },
        error: function () {
            $('#rs').innerHTML = rs;
            document.getElementById('note').innerHTML = "Error: The product doesn't exist.";
            $('#handler-note').click();
        }
    });
}

(我将一些单词翻译成英文,原文为西班牙文,并使其更具可读性)

因此,cot []数组会保留产品的id和数量,以便在下一个代码中使用它们,该代码在列表完成后运行,并且您点击了一个调用此函数的保存按钮:

function ncotiza () {

  event.returnValue=false;

  var nlist = $('#codp').val();
  var day = $('#days').val();

  $.ajax({
    async: false,
    type: 'POST',
    data: ({listnumber: nlist, days : day}),
    url: 'process/ncot.php'
  });

  j = 0;

  while (j <= i) {

      if (cot[j][0] != 0 && cot[j][1] != 0) {
          var num = cot[j][0];
          var cant = cot[j][1];

          $.ajax({
            async: false,
            type: 'POST',
            data: ({ listnumber : nlist, prodid: num, amount : cant }),
            url: 'process/ncotpro.php',
            success: function () {
                alert('Success');
            }
          });

          cot[j][0] = 0;
          cot[j][1] = 0;
          j++;
      }

      if (j == i) {
          window.location.reload(1);
          alert("Finished Successfully");
      };
  }

}

这一切都运行良好,这是PHP:

(ncot.php)         

    $listnumber = isset($_POST["listnumber"]) ? $_POST["listnumber"] : '';
    $days = isset($_POST["days"]) ? $_POST["days"] : '';

    $cons = "INSERT INTO pricelist (listnumber, diashabiles, cdate)
                VALUES ('$listnumber', '$days', CURDATE())";
    mysql_query($cons);

    ?>

(ncotpro.php)         

    $listnumber = isset($_POST["listnumber"]) ? $_POST["listnumber"] : '';
    $prodid = isset($_POST["prodid"]) ? $_POST["prodid"] : '';
    $amount = isset($_POST["amount"]) ? $_POST["amount"] : '';

    $cons = "SELECT price, um
                FROM inventory 
                WHERE listnumber = ".$prodid;

    $result = mysql_query($cons) or die ("Error: ".mysql_error());

    $row=mysql_fetch_assoc($result);
    $umcons = mysql_query("SELECT uvalue FROM um WHERE id = ".$row["um"]) or die ("Error:".mysql_error());
    $umres = mysql_fetch_assoc($umcons);
    $vuum = $umres["uvalue"];
    $fprice = $row["price"] * ($amount * $vuum);

    $cons = "INSERT INTO cotpro (cotizacion, producto, amount, monto)
                VALUES ('$listnumber', '$prodid', '$amount', '$fprice')";

    mysql_query($cons) or die ("Error: ".mysql_error());

    ?>

第一个ajax运行正常,然后它也会执行while内部的那个,并且它会抛出所有警报,但是当我检查数据库时,它只做了1行而不是全部它。

我很抱歉,如果它太明显或其他什么,我在这个页面看了很多问题和答案,我一直试图解决这个问题几个小时,但我只是没有看到它。

事先谢谢你。

1 个答案:

答案 0 :(得分:0)

尝试通过firebug调试第二个jquery文件。 你在i中返回的价值

while(j&lt; = i){  ..  ..