代码如下:
<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();

本文详细介绍了在角色编辑页面中,通过异步加载数据时遇到的角色信息不实时更新的问题,以及如何通过加入无用变量解决缓存问题,确保角色数据在修改后能正确显示。
1793

被折叠的 条评论
为什么被折叠?



