Page.RegisterRequiresControlState(Control) Método
Definição
Importante
Algumas informações dizem respeito a um produto pré-lançado que pode ser substancialmente modificado antes de ser lançado. A Microsoft não faz garantias, de forma expressa ou implícita, em relação à informação aqui apresentada.
Regista um controlo como aquele cujo estado de controlo deve ser mantido.
public:
void RegisterRequiresControlState(System::Web::UI::Control ^ control);
public void RegisterRequiresControlState(System.Web.UI.Control control);
member this.RegisterRequiresControlState : System.Web.UI.Control -> unit
Public Sub RegisterRequiresControlState (control As Control)
Parâmetros
- control
- Control
O controlo para registar.
Exceções
O controlo para registar é null.
O RegisterRequiresControlState(Control) método só pode ser chamado antes ou durante o PreRender evento.
Exemplos
O exemplo de código seguinte mostra um controlo de servidor personalizado que chama o RegisterRequiresControlState método.
public class Sample : Control {
private int currentIndex = 0;
protected override void OnInit(EventArgs e) {
Page.RegisterRequiresControlState(this);
base.OnInit(e);
}
protected override object SaveControlState() {
return currentIndex != 0 ? (object)currentIndex : null;
}
protected override void LoadControlState(object state) {
if (state != null) {
currentIndex = (int)state;
}
}
}
Class Sample
Inherits Control
Dim currentIndex As Integer
Protected Overrides Sub OnInit(ByVal e As EventArgs)
Page.RegisterRequiresControlState(Me)
currentIndex = 0
MyBase.OnInit(e)
End Sub
Protected Overrides Function SaveControlState() As Object
If currentIndex <> 0 Then
Return CType(currentIndex, Object)
Else
Return Nothing
End If
End Function
Protected Overrides Sub LoadControlState(ByVal state As Object)
If (state <> Nothing) Then
currentIndex = CType(state, Integer)
End If
End Sub
End Class
Observações
Os controlos personalizados de servidor que utilizam o estado de controlo devem chamar o RegisterRequiresControlState método em cada pedido porque o registo do estado de controlo não é transferido de um pedido para outro durante um evento de postback. Recomenda-se que o registo ocorra nesse Init caso.