溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

ASP.NET中EnableViewState屬性的作用是什么

發(fā)布時間:2021-07-15 15:22:13 來源:億速云 閱讀:134 作者:Leah 欄目:編程語言

ASP.NET中EnableViewState屬性的作用是什么,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

在ASP.NET中對各個WebForm控件引入以前沒有的EnableViewState屬性。這個屬性究竟有什么用。我們知道對于 WebForm而言,其代碼是在服務器端的,以處理客戶端的請求。當用戶通過瀏覽器瀏覽網(wǎng)頁的時候,會對網(wǎng)頁進行某些操作,比如打開新鏈接,或單擊某個按鈕。在ASP中,這些是通過腳本語言對其進行處理,之后再傳遞給服務器端。但是在ASP.NET下,由于采用了code behind技術,在coding的時候,通常是將以前客戶端完成的工作放到了服務器端。

那么,服務器是怎么知道客戶的操作的呢?比如我在文本框輸入的內容,或者單擊了登錄按鈕,服務器端是怎樣得到這些信息的呢?因為沒有這些信息,服務器端就無法響應客戶的請求。原理就是ASP.NET引用了viewstate的機制。在服務器端保存了網(wǎng)頁各個控件及頁面的狀態(tài),這其中包括各個控件在頁面上的布局,和他們各自的屬性。這些值就保存在ViewState下。我們可以觀察Aspx頁面的html源代碼,假設這個頁面上有一個button按鈕,和一個listBox控件,html文件如下:

  1. <input type="hidden" name="__VIEWSTATE" value=
    "dDwzODYzNDM5NTU7Oz7FvviJbq45bDa7QJaumIiOhZ8mOQ==" />   

  2. <input type="submit" name="Button1" value="Button" id="Button1" style=
    "height:40px;width:96px;Z-INDEX: 101; LEFT: 200px; POSITION: absolute; 
    TOP: 240px"
     />   

  3. <select name="ListBox1" size="4" id="ListBox1" style="width:152px;
    Z-INDEX: 102; LEFT: 176px; POSITION: absolute; TOP: 120px"
    > 

  4. </select> 

我們它的不同之處,一是少了以前所必須響應客戶端事件的腳本語言,一是多了一個名為”_VIEWSTATE”的屬性。其值是一長串字符。類型為 “hidden”。這個值記錄的就是各個控件和頁面的狀態(tài)信息。當用戶對頁面進行相關操作的時候,狀態(tài)值發(fā)生改變,并將改變的值傳遞給服務器端。服務器端在比較改變后的狀態(tài)值和初始值之間的區(qū)別,以響應具體的請求。

一旦頁面的控件很多,這種頻繁的傳遞控件狀態(tài)值對網(wǎng)絡的消耗是很大的,因此,ASP.Net提供了EnableViewState屬性,系統(tǒng)默認的值為true。當設置為true時,在傳遞狀態(tài)值時就包括該控件;如果設置為false,則傳遞狀態(tài)值時則不包括它。既然狀態(tài)值不包括該控件,則客戶端對它進行的操作,服務器端是不響應的。

我們可以做個實驗,在Button1_Click事件中,編寫代碼:

ListBox.Items.Add(”客戶端點擊按鈕一次!”);

此時運行該應用程序,單擊網(wǎng)頁上的按鈕,在ListBox中會添加內容,不斷地單擊,內容則不斷添加。如果我們將ListBox的EnableViewState屬性改為false時,不斷單擊按鈕,則只能添加一次。

這樣有什么好處呢?如果我們在開發(fā)Web應用程序時,某些控件是不需要接受用戶的操作或只需要接受一次操作的時候,我們可以將這些控件的EnableViewState屬性改為false,這樣可以優(yōu)化我們的程序,提高網(wǎng)絡訪問的速度。

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業(yè)資訊頻道,感謝您對億速云的支持。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI