中文字幕第五页-中文字幕第页-中文字幕韩国-中文字幕最新-国产尤物二区三区在线观看-国产尤物福利视频一区二区

Asp.net程序優化js、css如何實現合并與壓縮-創新互聯

這篇文章主要為大家展示了“Asp.net程序優化js、css如何實現合并與壓縮”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“Asp.net程序優化js、css如何實現合并與壓縮”這篇文章吧。

站在用戶的角度思考問題,與客戶深入溝通,找到龍沙網站設計與龍沙網站推廣的解決方案,憑借多年的經驗,讓設計與互聯網技術結合,創造個性化、用戶體驗好的作品,建站類型包括:網站設計制作、成都網站制作、企業官網、英文網站、手機端網站、網站推廣、國際域名空間、網頁空間、企業郵箱。業務覆蓋龍沙地區。

具體實現方法如下:

訪問時將js和css壓縮并且緩存在客戶端,
采用的是Yahoo.Yui.Compressor組件來完成的,用戶可以點擊此處本站下載。

創建一個IHttpHandler來處理文件

public class CombineFiles : IHttpHandler
{
        private const string CacheKeyFormat = "_CacheKey_{0}_";
        private const bool IsCompress = true; //需要壓縮
        public bool IsReusable
        {
            get
            {
                return false;
            }
        }
        public void ProcessRequest(HttpContext context)
        {
            HttpRequest request = context.Request;
            HttpResponse response = context.Response;
            string cachekey = string.Empty;
            string type = request.QueryString["type"];
            if (!string.IsNullOrEmpty(type) && (type == "css" || type == "js"))
            {
                if (type == "js")
                {
                    response.ContentType = "text/javascript";
                }
                else if (type == "css")
                {
                    response.ContentType = "text/css";
                }
                cachekey = string.Format(CacheKeyFormat, type);
                CompressCacheItem cacheItem = HttpRuntime.Cache[cachekey] as CompressCacheItem;
                if (cacheItem == null)
                {
                    string content = string.Empty;
                    string path = context.Server.MapPath("");
                    //找到這個目錄下所有的js或css文件,當然也可以進行配置,需求請求壓縮哪些文件
                    //這里就將所的有文件都請求壓縮
                    string[] files = Directory.GetFiles(path, "*." + type);
                    StringBuilder sb = new StringBuilder();
                    foreach (string fileName in files)
                    {
                        if (File.Exists(fileName))
                        {
                            string readstr = File.ReadAllText(fileName, Encoding.UTF8);
                            sb.Append(readstr);
                        }
                    }
                    content = sb.ToString();
                    // 開始壓縮文件
                    if (IsCompress)
                    {
                        if (type.Equals("js"))
                        {
                            content = JavaScriptCompressor.Compress(content);
                        }
                        else if (type.Equals("css"))
                        {
                            content = CssCompressor.Compress(content);
                        }
                    }
                    //輸入到客戶端還可以進行Gzip壓縮 ,這里就省略了
                    cacheItem = new CompressCacheItem() { Type = type, Content = content, Expires = DateTime.Now.AddDays(30) };
                    HttpRuntime.Cache.Insert(cachekey, cacheItem, null, cacheItem.Expires, TimeSpan.Zero);
                }
                string ifModifiedSince = request.Headers["If-Modified-Since"];
                if (!string.IsNullOrEmpty(ifModifiedSince)
                    && TimeSpan.FromTicks(cacheItem.Expires.Ticks - DateTime.Parse(ifModifiedSince).Ticks).Seconds < 0)
                {
                    response.StatusCode = (int)System.Net.HttpStatusCode.NotModified;
                    response.StatusDescription = "Not Modified";
                }
                else
                {
                    response.Write(cacheItem.Content);
                    SetClientCaching(response, cacheItem.Expires);
                }
            }
        }
        private void SetClientCaching(HttpResponse response, DateTime expires)
        {
            response.Cache.SetETag(DateTime.Now.Ticks.ToString());
            response.Cache.SetLastModified(DateTime.Now);
            //public 以指定響應能由客戶端和共享(代理)緩存進行緩存。   
            response.Cache.SetCacheability(HttpCacheability.Public);
            //是允許文檔在被視為陳舊之前存在的最長絕對時間。
            response.Cache.SetMaxAge(TimeSpan.FromTicks(expires.Ticks));
            response.Cache.SetSlidingExpiration(true);
        }
        private class CompressCacheItem
        {
            /// <summary>
            /// 類型 js 或 css
            /// </summary>
            public string Type { get; set; } // js css 
            /// <summary>
            /// 內容
            /// </summary>
            public string Content { set; get; }
            /// <summary>
            /// 過期時間
            /// </summary>
            public DateTime Expires { set; get; }
        }
}

最后在配置文件中配置一下CombineFiles.axd文件,具體配置略

引用如下

<script type="text/javascript" src="/js/CombineFiles.axd?type=js"></script>
<link rel="stylesheet" type="text/css" href="/css/CombineFiles.axd?type=css" />

以上是“Asp.net程序優化js、css如何實現合并與壓縮”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注創新互聯行業資訊頻道!

當前文章:Asp.net程序優化js、css如何實現合并與壓縮-創新互聯
網站鏈接:http://m.2m8n56k.cn/article6/dppjog.html

成都網站建設公司_創新互聯,為您提供網站導航小程序開發定制開發面包屑導航營銷型網站建設微信小程序

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:[email protected]。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

網站建設網站維護公司
主站蜘蛛池模板: 99re热精品视频国产免费 | 国产亚洲人成a在线v网站 | 97在线视频免费播放 | 国产精品自拍合集 | 日本三级香港三级妇三 | 免费国产成人α片 | 国产成人啪一区二区 | 亚洲国产精品一区二区首页 | 欧美性色高清生活片 | 亚洲精品国产精品国自产网站 | 国产伦理久久精品久久久久 | 亚洲一级毛片视频 | 欧美视频一区二区三区 | 91亚洲国产成人久久精品网站 | 中文精品爱久久久国产 | 日韩精品另类天天更新影院 | 作爱视频在线免费观看 | 久久精品国产亚洲高清 | 毛片视频免费观看 | 国产一区二区三区视频 | 亚洲人成在线影院 | 国产一区二区三区视频在线观看 | 国产午夜视频 | 国产成人丝袜视频在线视频 | 亚洲国产欧美精品 | 另类一区二区三区 | 国产免费爱在线观看视频 | 亚洲天堂视频在线观看免费 | 欧美精品成人久久网站 | 日韩毛片免费在线观看 | 在线视频一区二区三区在线播放 | 欧美国产三级 | 黄色一级片网址 | 欧美精品片在线观看网站 | 久久福利青草精品资源站免费 | 国产一级爱做片免费观看 | 久久九九热视频 | 久久成人免费视频 | 国产亚洲亚洲精品777 | xxx免费视频| 日韩视频一区二区 |