好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > Asp.net程序優化js、css實現合并與壓縮的方法

Asp.net程序優化js、css實現合并與壓縮的方法

熱門標簽:400電話辦理最優質 t3出行地圖標注怎么做 威海電銷 外呼電銷機器人軟件 寧夏機器人電銷 400免費電話怎么辦理 河南語音外呼系統公司 河北網絡回撥外呼系統 關于宗地圖標注技術規范

本文實例講述了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程序設計有所幫助。

您可能感興趣的文章:
  • 使用asp.net MVC4中的Bundle遇到的問題及解決辦法分享
  • 基于Asp.Net MVC4 Bundle捆綁壓縮技術的介紹
  • asp.net Bundle功能擴展
  • ASP.NET MVC Bundles 用法和說明(打包javascript和css)
  • ASP.NET MVC中使用Bundle打包壓縮js和css的方法
  • 淺談ASP.NET中MVC 4 的JS/CSS打包壓縮功能
  • Asp.net MVC下使用Bundle合并、壓縮js與css文件詳解

標簽:淮北 咸寧 吉林 樂山 賀州 池州 固原 廣元

巨人網絡通訊聲明:本文標題《Asp.net程序優化js、css實現合并與壓縮的方法》,本文關鍵詞  Asp.net,程序,優化,css,實現,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Asp.net程序優化js、css實現合并與壓縮的方法》相關的同類信息!
  • 本頁收集關于Asp.net程序優化js、css實現合并與壓縮的方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 中国丰满女人特级A片| 色婷婷激情| 日韩精品 电影一区 亚洲| 国产不雅视频| 绑定jy收集系统| 丝宝vip各种丝袜无内裤私摄| 怀孕还被c的小黄文| 公翁让我挺进去满足了我视频| 亚洲国产精品第一区二区三区| 做几次下面就会松| 亚洲无限资源| 久久xxxx| 泳池内疯狂揉捏呻吟声| 老师你下面好紧好湿h| 四虎影视国产884a精品亚洲| 国内外成人在线视频| 牝教师 婬辱の教室| 日本护士xxxx爽爽爽| 十大禁用软件app黄台大全下载 | 欧美xx性| 91嫩草丨国产丨精品入口| 真实男女xx00动态视频120秒| 欧美成人免费tv在线播放| 亚洲天堂网2014| 欧美性黑人巨大gaysex| 黄色一级免费电影| 成人精品A片免费观看直播69 | 成人污漫| 欧美第1页| 啊啊啊啊啊啊啊啊轻点| 国产秒拍福利| 动漫男男车车好快的车车图| 老汉扛起娇妻玉腿进入h文| jzzjzz日本丰满成熟少妇| 欧美AV重口另类777| 性船在线| 色欲五月一区熟女av| 国产精品在线| 国模白灵大尺度啪啪人体| 国产在线麻豆秘?二次苍井空 | 明星ai人脸替换脸网站免费|