我正在制作一个库存表,用户可以输入一定数量的库存来发出,这个功能是为表中的每个成员验证数据库中的库存数量足以解决问题。
当我通过Chrome上的代码断点时,似乎永远不会点击$ .post的内部代码,直到它完成循环遍历表。到那时,应该传递给AddIssue的数据只变为1和10而不是其他任何东西。
它开始让我发疯,所以我很欣赏指出我在这里做错了什么
var issueArray =[];
function VerifyIssue()
{
var numRows = document.getElementById("searchTable").rows.length - 2;
var running = true;
var str1 = "issue_";
while(running == true)
{
if (numRows < 0 && running == true)
{
running = false;
//insert code for success
break;
}
else if (running == false)
{
break;
}
var str2 = numRows;
var comb = str1.concat(str2);
var issue_element = document.getElementById(comb);
var q = issue_element.value;
var i = issue_element.name;
var idd = i.replace("issue_", "");
var trimId = idd.trim();
$.post
(
'includes/issueCheck.php',
{
id: trimId,
issueQuantity: q
},
function(result)
{
alert(result);
if (result < 0)
{
alert("One of more quantities inputted are greater than held in stock");
running = false;
}
if (result > 0)
{
addIssue(trimId, q);
}
}
);
numRows = numRows - 1;
}
alert(issueArray);
}
function addIssue(issueID, quant)
{
var item = {};
item.label = issueID;
item.value = quant;
issueArray.push(item);
}
这是由$ .post
调用的PHP<?php
$server = 'SQL2008';
$connectionInfo = array( "Database"=>"rde_470585");
$conn = sqlsrv_connect($server,$connectionInfo);
$false = -1;
$true = 1;
$id = $_POST['id'];
$quantity = $_POST['issueQuantity'];
$query = "Select Quantity FROM Stock WHERE StockID = ?";
$param = array($id);
$res = sqlsrv_query($conn, $query, $param);
$row = sqlsrv_fetch_array($res, SQLSRV_FETCH_ASSOC);
$dbQuantity = $row['Quantity'];
if ($dbQuantity < $quantity)
{
echo $false;
}
else if($dbQuantity >= $quantity)
{
echo $true;
}
答案 0 :(得分:0)
您是否意识到只有在收到您的POST请求的服务器响应时才会调用您的函数(结果){...}?您必须构建代码以考虑延迟。
答案 1 :(得分:0)
我还在研究这个问题,根据@jojo所说的内容阅读Promises,但不确定它是否对我有效。
如何在恢复之前让javascript等待服务器响应?