程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> ASP.NET >> 關於ASP.NET >> ASP.NET OutputCache詳解

ASP.NET OutputCache詳解

編輯:關於ASP.NET

       這篇文章主要介紹了ASP.NET OutputCache詳解,本文詳細講解了OutputCache的語法、OutputCache的參數、OutputCache使用示例等內容,需要的朋友可以參考下

      當用戶訪問頁面時,整個頁面將會被服務器保存在內存中,這樣就對頁面進行了緩存。當用戶再次訪問該頁,頁面不會再次執行數據操作,頁面首先會檢查服務器中是否存在緩存,如果緩存存在,則直接從緩存中獲取頁面信息,如果頁面不存在,則創建緩存。

      頁面輸出緩存適用於那些數據量較多,而不會進行過多的事件操作的頁面,如果一個頁面需要執行大量的事件更新,以及數據更新,則並不能使用頁面輸出緩存。使用@OutputCatch指令能夠聲明頁面輸出緩存,示例代碼如下所示。

      代碼如下:

      <%@ OutputCache Duration="120" VaryByParam="none" %>

      上述代碼使用@OutputCatch指令聲明了頁面緩存,該頁面將被緩存120秒。@OutputCatch指令包括10個屬性,通過這些屬性能夠分別為頁面的不同情況進行緩存設置,常用的屬性如下所示:

      CacheProfile:獲取或設置OutputCacheProfile名稱。

      Duration:獲取或設置緩存項需要保留在緩存中的時間。

      VaryByHeader:獲取或設置用於改變緩存項的一組都好分隔的HTTP標頭名稱。

      Location:獲取或設置一個值,該值確定緩存項的位置,包括Any、Clint、Downstream、None、Server和ServerAndClient。默認值為Any。

      VaryByControl:獲取或設置一簇分好分隔的控件標識符,這些標識符包含在當前頁或用戶控件內,用於改變當前的緩存項。

      NoStore:獲取或設置一個值,該值確定是否設置了“Http Cache-Control:no-store”指令。

      VaryByCustom:獲取輸出緩存用來改變緩存項的自定義字符串列表。

      Enabled:獲取或設置一個值,該值指示是否對當前內容啟用了輸出緩存。

      VaryByParam:獲取查詢字符串或窗體POST參數的列表。

      通過設置相應的屬性,可以為頁面設置相應的緩存,當需要為Default.aspx設置緩存項時,可以使用VaryByParam屬性進行設置,示例代碼如下所示。

      代碼如下:

      <%@ OutputCache Duration="120" VaryByParam="none" %>

      上述代碼使用了Duration屬性和VarByParam屬性設置了當前頁的緩存屬性。為一個頁面進行整體的緩存設置往往是沒有必要的,常常還會造成困擾,例如Default.aspx?id=1和Default.aspx?id=100在緩存時可能呈現的頁面是相同的,這往往不是開發人員所希望的。通過配置VarByParam屬性能夠指定緩存參數,示例代碼如下所示。

       代碼如下:

      <%@ OutputCache Duration="120" VaryByParam="id" %>

      上述代碼則通過參數id進行緩存,當id項不同時,ASP.NET所進行的頁面緩存也不盡相同。這樣保證了Default.aspx?id=1和Default.aspx?id=100在緩存時所顯示的頁面並不一致。VarByHeader和VarByCustom主要用於根據訪問頁面的客戶端對頁面的外觀或內容進行自定義。在ASP.NET中,一個頁面可能需要為PC用戶和MOBILE用戶呈現輸出,因此可以通過客戶端的版本不同來緩存不同的數據,示例代碼如下所示。

      代碼如下:

      <%@ OutputCache Duration="120" VaryByParam="none" VaryByCustom="browser" %>

      上述代碼則為每個浏覽器單獨設置了緩存條目。

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved