您的当前位置:首页正文

解决easyUI1.2.6+datagrid在IE浏览器下无法重新加载、查询

2020-11-09 来源:星星旅游

I) easyUI 1.2.6 datagrid在 IE浏览器目前存在的问题 1:无法重新加载、查询 var row = $('#dg_user_table').datagrid('getSelected'); $('#dg_userPri_table').datagrid( { method : 'POST', height : 280, url : remotePathq 'user/role/' row.id, 。。

I) easyUI 1.2.6 + datagrid在 IE浏览器目前存在的问题

1:无法重新加载、查询

var row = $('#dg_user_table').datagrid('getSelected');

$('#dg_userPri_table').datagrid(
{
method : 'POST',
height : 280,
url : remotePathq + 'user/role/' + row.id,

。。。

});

BUG:在没有清空IE缓存或者关闭IE重新打开,会出现查询数据为上次的缓存、历史数据,非即时数据:(其它firefox,谷歌浏览器正常)



原因:datagrid发送的'POST'请求地址一样,导致IE浏览器不会重新查询数据,而是从上次的缓存里直接获取历史数据;



2 :reload方法使用无效:

即$('#dg_user_table').datagrid('reload');不触发datagrid URL请求,数据没有更新;

原因:datagrid发送的'POST'请求地址一样,导致IE浏览器不会重新查询数据,而是从上次的缓存里直接获取历史数据;(同上)


II)解决办法:

对HTTP RESTFUL服务地址加上唯一值随机数,区别每次加载的RESTFUL服务地址;

即:

var randomNu = (new Date().getTime()) ^ Math.random();

url : remotePathq + 'user/role/' + row.id+"?_="+randomNu,

修正后为:

var row = $('#dg_user_table').datagrid('getSelected');

var randomNu = (new Date().getTime()) ^ Math.random();

$('#dg_userPri_table').datagrid(
{
method : 'POST',
height : 280,
url : remotePathq + 'user/role/' + row.id+"?_="+randomNu,

。。。

});

便可解决1 2 问题,使reload方法也可用;