代码如下:
<script> var roleId; $.(function(){ roleId = '${roleId}'; if (roleId != null && roleId != "" && roleId != 0){ var url = '${rootPath}/role/getRoleById?roleId=' + roleId; $.('#dataForm').form('load',url); } }); </script>
@RequestMapping("/getRoleById")
@ResponseBody
public Map getRoleById(@RequestParam("roleId") String roleId){
Map map = new HashMap();
map.put("roleId", roleId);
return roleAction.fineOne(map);
}
功能是,当进入roleEdit编辑页面,通过异步调用getRoleById方法然后填充表单。
但是出现的问题是,当修改成功后,再次进入该角色的roleEdit页面,读取出来的内容还是修改之前的数据。但是数据库中确确实实已经修改成功了。通过在getRoleById打断点发现,只有一个新的role第一次进入roleEdit页面时,才会进入断点,之后就再也不会进入了。
然后怀疑是mybatis的缓存问题,后来发现又不是。
最后确定的是异步缓存问题,只需要在提交的url中加入无用的变量,让新url和之前的url不一样就行。
比如url改成:var url = '${rootPath}/role/getRoleById?roleId=' + roleId + '&tmp=' + Math.random();