Control.SaveViewState Yöntem

Tanım

Sayfanın sunucuya geri gönderildiği zamandan bu yana gerçekleşen tüm sunucu denetimi görünüm durumu değişikliklerini kaydeder.

protected:
 virtual System::Object ^ SaveViewState();
protected virtual object SaveViewState ();
abstract member SaveViewState : unit -> obj
override this.SaveViewState : unit -> obj
Protected Overridable Function SaveViewState () As Object

Döndürülenler

Sunucu denetiminin geçerli görünüm durumunu döndürür. Denetimle ilişkilendirilmiş görünüm durumu yoksa, bu yöntem döndürür null.

Örnekler

Aşağıdaki örnek, özel bir ASP.NET sunucu denetiminde yöntemini geçersiz kılar SaveViewState . Bu yöntem çağrıldığında, denetimin herhangi bir alt denetime sahip olup olmadığını ve içeren Page nesnenin bir geri göndermenin sonucu olup olmadığını belirler. Her ikisi de doğruysa, web sunucusu denetiminin TextLabel özelliğini okuyacak Custom Control Has Saved Stateşekilde değiştirir. Ardından denetimin görünüm durumunu adlı allStatesbir nesne dizisi olarak kaydeder.

protected override object SaveViewState()
{  // Change Text Property of Label when this function is invoked.
   if(HasControls() && (Page.IsPostBack))
   {
      ((Label)(Controls[0])).Text = "Custom Control Has Saved State";
   }
   // Save State as a cumulative array of objects.
   object baseState = base.SaveViewState();
   string userText = UserText;
   string passwordText = PasswordText;
   object[] allStates = new object[3];
   allStates[0] = baseState;
   allStates[1] = userText;
   allStates[2] = PasswordText;
   return allStates;
}
Protected Overrides Function SaveViewState() As Object
   ' Change Text Property of Label when this function is invoked.
   If HasControls() And Page.IsPostBack Then
      CType(Controls(0), Label).Text = "Custom Control Has Saved State"
   End If
   ' Save State as a cumulative array of objects.
   Dim baseState As Object = MyBase.SaveViewState()
   Dim _userText As String = UserText
   Dim _passwordText As String = PasswordText
   Dim allStates(3) As Object
   allStates(0) = baseState
   allStates(1) = _userText
   allStates(2) = PasswordText
   Return allStates
End Function

Açıklamalar

Görünüm durumu, sunucu denetiminin özelliklerinin değerlerinin birikmesidir. Bu değerler, sınıfın bir örneği olan sunucu denetiminin ViewState özelliğine StateBag otomatik olarak yerleştirilir. Bu özelliğin değeri, sunucu denetimi yaşam döngüsünün kaydetme durumu aşamasından sonra bir dize nesnesine kalıcı hale getirilir. Daha fazla bilgi için bkz. ASP.NET Sayfa Yaşam Döngüsüne Genel Bakış.

Görünüm durumu kaydedildiğinde, bu dize nesnesi istemciye bir HTML HIDDEN öğesinde depolanan bir değişken olarak döndürülür. Özel görünüm durumuna sahip bir özel sunucu denetimi yazdığınızda, görünüm durumu ve LoadViewState yöntemleriyle SaveViewState açıkça yönetilebilir. Daha fazla bilgi için bkz. ASP.NET Durum Yönetimine Genel Bakış. Özel oturum durumu sağlayıcısı uygulama hakkında bilgi için bkz. Session-State Deposu Sağlayıcısı Uygulama.

Şunlara uygulanır

Ayrıca bkz.