对于dwr处理同步有关问题
对于dwr处理同步问题
摘抄别人的 留着自用
有时会出现在服务器端执行了..并将值赋值给了客户端.但是客户端取的时候没有得到值..
出现的原因:因为AJAX采用的是异步的执行方式(默认),当客户端执行之后服务器端还没有执行完。。解决的方法就是将其执行的方式改成同步。。。
在dwr中的改法:eg:
客户端代码:
java代码:
摘抄别人的 留着自用
有时会出现在服务器端执行了..并将值赋值给了客户端.但是客户端取的时候没有得到值..
出现的原因:因为AJAX采用的是异步的执行方式(默认),当客户端执行之后服务器端还没有执行完。。解决的方法就是将其执行的方式改成同步。。。
在dwr中的改法:eg:
客户端代码:
//id是从标签中传过来的.
function validateOperationReason(id) {
//将ajax的执行方式改成同步,默认是异步的
DWREngine.setAsync(false);
//当要传递多个参数的时候就应该用下面的方式:
//其中operationReason,,id相当于key值.在服务器端取出来的时候则要使用map
var data = {operationReason:$("reasonDescription").value,id:id};
operReasonManager.updateValidate(data,function(str) {
$("reasonDescriptionMsg").innerHTML=str;
});
//恢复现场
DWREngine.setAsync(true);
}
java代码:
public String updateValidate(Map argus) {
String operationReason =argus.get("operationReason").toString();
int id = Integer.parseInt(argus.get("id").toString());
if(operationReason!=null && !"".equals(operationReason.trim())) {
String sql = "select * from dbpos.dbo.ph_operation_reason where id <>"+id+" and reason_description='"+operationReason.trim()+"'";
if(jt.queryForList(sql).size() > 0) {
return "该操作原因已存在..不能取相同的";
}
}
return "";
}