gpt4 book ai didi

javascript - 使用 SeedStack 中的 RequireJS 防止 Javascript 文件的浏览器缓存问题

转载 作者:行者123 更新时间:2023-11-29 19:23:23 25 4
gpt4 key购买 nike

使用 SeedStack 14.7 我们在服务器上上传新版本时面临缓存问题:每个用户都必须清除缓存才能获取文件的最新版本。

我尝试在片段 JSON 文件的 requireConfig 部分使用 "urlArgs": "version=2" 。它通过在每个文件上添加参数来完成这项工作,因此我们可以在更改版本时使用它,但它也会影响每个模块配置中的 url!

当我们使用此配置将 REST 基本 url 传递给每个模块时,它通过将参数添加到基本 url 来中断所有 REST 请求。

我的片段 JSON 文件:

{
"id": "mac2-portail",
"modules": {
"gestionImage": {
"path": "{mac2-portail}/modules/gestionImage",
"autoload": true,
"config": {
"apiUrl": "muserver/rest"
}
}
},
"i18n": {...},
"routes": {...},
"requireConfig": {
"urlArgs": "version=2",
"shim": {...}
}
}

有什么办法可以在不中断 REST 请求的情况下解决缓存问题吗?

编辑:它不是 Prevent RequireJS from Caching Required Scripts 的副本.是的,SeedStack 使用了 RequireJS,这个配置解决了缓存问题,但它也会影响片段中定义的其他模块,所以我需要找到另一种解决方案来防止浏览器缓存文件

最佳答案

模块配置值,如apiUrl在您的示例中,除非您调用 require.toUrl(),否则不会被 RequireJS 触及明确地在他们身上。我认为这就是您的情况。为避免此问题,您应该始终先进行串联,然后才调用 require.toUrl()在完整的结果 URL 上。

所以,与其这样做:

var fullUrl = require.toUrl(config.apiUrl) + '/my/resource';

这样做:

var fullUrl = require.toUrl(config.apiUrl + '/my/resource');

顺便说一句,您可以简单地将应用程序的版本添加到 data-w20-app-version 中,而不是直接在 RequireJS 配置中设置版本。 <html> 上的属性母版页的元素:

<html data-w20-app data-w20-app-version="2.0.0">

这将提供相同的行为,但在 $templateCache 中的 Angular 模板的情况下会正常工作.如果您的母版页是由后端自动生成的,那么这是自动完成的。检查this page了解详情。

关于javascript - 使用 SeedStack 中的 RequireJS 防止 Javascript 文件的浏览器缓存问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32091617/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com