Control.SaveViewState Yöntem

Tanım

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

C#
protected virtual object SaveViewState();

Döndürülenler

Sunucu denetiminin geçerli görünüm durumunu döndürür. Denetimle ilişkilendirilmiş bir 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, bir Web sunucusu denetiminin Label özelliğini okuyacak Custom Control Has Saved Stateşekilde değiştirirText. Ardından denetimin görünüm durumunu adlı allStatesbir nesne dizisi olarak kaydeder.

C#
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;
}

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. Daha sonra 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ı olur. Daha fazla bilgi için bkz. sayfa yaşam döngüsüne genel bakış ASP.NET.

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 durumuyla özel bir 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

Ürün Sürümler
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1

Ayrıca bkz.