动态生成js数据Response.Expires=1440竟然无效?

项目当中有一些数据,比如多语言翻译,要求做语言包,起初当然是做成i18n.js文件,但是每个阶段版本更新都会增加一些key,那么发布的时候只能给<script>的src增加?20180913版本号,令客户端加载新的js。

这么做其实很不方便,平时发布可能忘记更新母版的script版本号。

现在这里有比较一劳永逸的方式:

1、编写Controller,比如

    public class LangController : Controller
    {
        public ActionResult Js(string langType)
        {
             var data = Get你的数据源(langType);
             Response.Write("var lang = "data);

         Response.ContentType = "application/x-javascript";
         Response.Expires = 1440;

        }
     }  

2、修改你的引用

<script src="/lang/js"></script>

ok,你的js数据源在客户端将缓存1天,确保第2天能取新的(要是觉得不够可以改成1小时、6小时),确保晚间你的发布,用户第二天不会用旧的js。

测试:

Webkit内核,访问,跳转一次URL,显示form cache,确定不会短时间内重复加载。

IE11测试,首次访问

跳转URL,纳尼!怎么还是重新加载。

经过一轮百度、Bing、谷歌之后,消耗2小时调试时间…

增加代码

Response.Write("document.write(‘" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + "‘);");

关掉IE的F12

IE11测试,首次访问

跳转URL,OK有效。

原因,IE11如果开着F12,会忽略Expires限制,将为你访问服务器获取新资源。

虚惊一场,是不是浪费表情了

原文地址:https://www.cnblogs.com/ycbt/p/9639814.html

时间: 2024-11-10 18:22:58

动态生成js数据Response.Expires=1440竟然无效?的相关文章

python爬取ajax动态生成的数据 以抓取淘宝评论为例子

在学习python的时候,一定会遇到网站内容是通过ajax动态请求.异步刷新生成的json数据的情况,并且通过python使用之前爬取静态网页内容的方式是不可以实现的,所以这篇文章将要讲述如果在python中爬取ajax动态生成的数据. 至于读取静态网页内容的方式,有兴趣的可以查看博客内容. 这里我们以爬取淘宝评论为例子讲解一下如何去做到的. 这里主要分为了四步: 一 获取淘宝评论时,ajax请求链接(url) 二 获取该ajax请求返回的json数据 三 使用python解析json数据 四

jquery easyui树的简答构造+动态生成js全局变量

jquery easyui树的简答构造: JSP页面 组织机构: <input id="p_organId" name="p_organId" style="width: 160px;height: 28px;"> function loadOrgan(){ organ_combotree = $("#p_organId").combotree({ url:'${ctxFront}/cust/tree', mult

js,css随笔(动态生成的dom做点击事件无效)

1.动态生成的DOM做点击事件无效   https://blog.csdn.net/mm_hello11/article/details/79010679 2.消除button的默认样式 margin: 0; padding: 0; border: 1px solid transparent; //自定义边框 outline: none; //消除默认点击蓝色边框效果 3. 键盘按下事件 $("#btn").keydown(function(event){ if(event.keyCo

东软软件动态生成对数据表更新操作的方法

1 public string CreatUpdate() 2 { 3 4 StringPlus strclass = new StringPlus(); 5 StringPlus strclass1 = new StringPlus(); 6 StringPlus strclass2 = new StringPlus(); 7 //方法注释 8 strclass.AppendSpaceLine(2, "/// <summary>"); 9 strclass.AppendS

动态生成的DOM做点击事件无效

有时候我们的标签都是从后台获取的数据,然后利用JS添加到页面上,当我们写生成的标签的点击事件(click)时没有效果. 例如: <section> 测试动态生成的DOM点击事件 <br /> </section> <script src="jquery-1.11.2.min.js"></script> <script> $(function () { $.ajax({ type: "post",

漂亮的表格样式;jQuery清楚表格所有行;js解析后台传过来的JSON数据;动态生成表格数据

一 : 先看看漂亮的表格 css代码: .mylist { width: auto; height:auto; border:1px solid #accdf4; margin-top:10px; font-family:"宋体"; font-size:12px; color:#155c9f; text-align:center; border-collapse: collapse; } .mylist th { background-color:#d0e4ff; text-align

动态生成JS

private void GenerateDrugAndProdJavaScript() { StringBuilder script = new StringBuilder(); script.Append("<script type=text/javascript>"); script.Append("function selectDrugAndProd(){"); script.Append("var drug = document.ge

抓取js动态生成数据

最近在抓数据,一般的网页数据抓取相对容易一些,今天在抓电视猫的节目单,发现有些数据时抓取不到的,Java端得到的HTML文件里面没有某一段代码,查了很多资料,发现说是js动态生成的数据,无法直接抓取,有一种解决方法是利用找到ajax请求地址和参数,重新抓取,该方法存在一个问题,就是当参数被加密过时,该方法就不好用了,所以,这里用了一个办法,就是利用HTMLunit来抓取(可以利用jsuop来处理HTML文件),jar包下载地址:http://download.csdn.net/detail/jo

JS动态生成表格后 合并单元格

JS动态生成表格后 合并单元格 最近做项目碰到表格中的单元格合并的问题,需求是这样的,首先发ajax请求 请求回来后的数据 动态生成表格数据,但是生成后如果编号或者(根据其他的内容)有相同时,要合并单元格操作,在做之前也试着google下,但是网上没有碰到这方面的需求,所以自己写了一个简单的.用文字描述需求太费劲了,如下图所示: 1. 没有合并之前的图如下: 2. 合并之后的图如下: 如上所示:是根据相邻的编号相同 进行单元格合并. 先看看实现后的效果再聊吧! JSfiddle链接地址如下: 点