我使用achor标签使用ajax调用此UpdateItem函数。 它给了我控制台错误
错误: req未定义
function updateItem(id, desc, vehicleno){
alert("i am here");
$('#ProcessModal').modal('show');
$('#<%=txtPartNo.ClientID%>')[0].value=id;
$('#<%=txtPartNo.ClientID%>')[0].value=partno;
}
Ajax调用...
......
$.ajax({
type: "POST",
contentType: "application/json; charset=utf-8",
url: "<%=BasePath%>/WebServices/RequisitionService.asmx/GetAllRequisitionItems",
data: '{ ReqID: "<%=_RecordId%>"}',
dataType: "json",
success: function (data) {
var req=[];
var desc=[];
var veh=[];
for (var i = 0; i < data.d.length; i++) {
req[i] =data.d[i].RequisitionItemsID;
desc[i]= data.d[i].ItemDescription;
veh[i]= data.d[i].VehicleNumber;
$("#reqTable").append("<tr><td>"+data.d[i].PartNo + "</td><td>" + data.d[i].ItemDescription +"</td><td>"+data.d[i].Quantity+"</td><td>"+data.d[i].VehicleNumber+"</td><td> " + data.d[i].ItemStatus +"</td><td>"+ data.d[i].Remarks+"</td><td><a href='javascript:updateItem(req[i], desc[i], veh[i] );'>Process</a> </td></tr>");
}
},
error: function (result) {
},
});
....
答案 0 :(得分:1)
实际上很容易,除了引号之外你没有做错任何事。 请按照以下方式纠正它们,它会起作用。
声明:
var req='';
var desc='';
ar veh='';
并在您需要这些变量的函数中。
<a href='javascript:updateItem(\"" + req + "\", \"" + desc + "\",\"" + veh + "\" );' <%= (ReqStage == (int)RequisitionStage.PendingforHOApproval) ? "" : "style=display:none" %>>Process</a> </td></tr>");
希望它有所帮助 快乐编码:)
答案 1 :(得分:0)
使用JavaScript Array push()方法。喜欢 -
req.push(data.d[i].RequisitionItemsID);
desc.push(data.d[i].ItemDescription);
veh.push(data.d[i].VehicleNumber);