您听起来好像您的 JavaScript 无法通过 Ajax 方法获取它加载的数据的更新版本,对吗?例如,如果两个 Ajax 调用尝试加载“data.txt”,那么第二个调用仅使用缓存版本。
您也可能无法加载脚本本身的新版本。
解决这两个问题的方法是将随机生成的查询字符串添加到您的脚本源和 Ajax 源中。
例如,制作一个加载主脚本的脚本,如下所示:
/* loader1.js */
document.write('<script src="mainjavascript.js?.rand=', Math.random(), '"></script>');
在您的 HTML 中,只需执行
<script src="loader1.js"></script>
同样的方法也适用于 JavaScript Ajax 请求。假设“client”是一个新的 XMLHttpRequest() 对象,并且已经正确设置了 readystatechange 函数等,那么您只需附加相同的查询字符串,如下所示:
request = client.open('GET', 'data.txt?.rand=' + Math.random(), true);
request.send();
您可能正在使用一个库来执行您的 Ajax 请求,因此它更容易。只需将数据 URL 指定为,'data.txt?.rand=' + Math.random()
而不仅仅是“data.txt”