ClientScriptManager.IsStartupScriptRegistered Método

Definição

Determina se o script de arranque está registado com o Page objeto.

Sobrecargas

Name Description
IsStartupScriptRegistered(Type, String)

Determina se o script de arranque está registado com o Page objeto usando a chave e o tipo especificados.

IsStartupScriptRegistered(String)

Determina se o script de arranque está registado com o Page objeto usando a chave especificada.

IsStartupScriptRegistered(Type, String)

Determina se o script de arranque está registado com o Page objeto usando a chave e o tipo especificados.

public:
 bool IsStartupScriptRegistered(Type ^ type, System::String ^ key);
public bool IsStartupScriptRegistered(Type type, string key);
member this.IsStartupScriptRegistered : Type * string -> bool
Public Function IsStartupScriptRegistered (type As Type, key As String) As Boolean

Parâmetros

type
Type

O tipo de script de arranque a procurar.

key
String

A chave do script de arranque a procurar.

Devoluções

true se o script de arranque estiver registado; caso contrário, false.

Exceções

O tipo de script de arranque é null.

Exemplos

O exemplo de código seguinte demonstra a utilização do IsStartupScriptRegistered método. Note-se que, se a lógica para verificar o bloco de script de arranque existente fosse removida, não haveria dois scripts duplicados de arranque no código-fonte HTML da página renderizada porque o RegisterStartupScript método verifica duplicados. O benefício da verificação é reduzir computação desnecessária.

<%@ Page Language="C#"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<script runat="server">
  public void Page_Load(Object sender, EventArgs e)
  {
    // Define the name and type of the client scripts on the page.
    String csname1 = "PopupScript";
    String csname2 = "ButtonClickScript";
    Type cstype = this.GetType();
        
    // Get a ClientScriptManager reference from the Page class.
    ClientScriptManager cs = Page.ClientScript;

    // Check to see if the startup script is already registered.
    if (!cs.IsStartupScriptRegistered(cstype, csname1))
    {
      String cstext1 = "alert('Hello World');";
      cs.RegisterStartupScript(cstype, csname1, cstext1, true);
    }

    // Check to see if the client script is already registered.
    if (!cs.IsClientScriptBlockRegistered(cstype, csname2))
    {
      StringBuilder cstext2 = new StringBuilder();
      cstext2.Append("<script type=\"text/javascript\"> function DoClick() {");
      cstext2.Append("Form1.Message.value='Text from client script.'} </");
      cstext2.Append("script>");
      cs.RegisterClientScriptBlock(cstype, csname2, cstext2.ToString(), false);
    }
  }
</script>
<html xmlns="http://www.w3.org/1999/xhtml" >
  <head>
    <title>ClientScriptManager Example</title>
  </head>
  <body>
     <form id="Form1"
         runat="server">
        <input type="text" id="Message" /> <input type="button" value="ClickMe" onclick="DoClick()" />
     </form>
  </body>
</html>
<%@ Page Language="VB" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<script runat="server">

  Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs)

    ' Define the name and type of the client scripts on the page.
    Dim csname1 As String = "PopupScript"
    Dim csname2 As String = "ButtonClickScript"
    Dim cstype As Type = Me.GetType()
    
    ' Get a ClientScriptManager reference from the Page class.
    Dim cs As ClientScriptManager = Page.ClientScript

    ' Check to see if the startup script is already registered.
    If (Not cs.IsStartupScriptRegistered(cstype, csname1)) Then
      
      Dim cstext1 As String = "alert('Hello World');"
      cs.RegisterStartupScript(cstype, csname1, cstext1, True)
      
    End If
    
    ' Check to see if the client script is already registered.
    If (Not cs.IsClientScriptBlockRegistered(cstype, csname2)) Then
      
      Dim cstext2 As New StringBuilder()
            cstext2.Append("<script type=""text/javascript""> function DoClick() {")
      cstext2.Append("Form1.Message.value='Text from client script.'} </")
      cstext2.Append("script>")
      cs.RegisterClientScriptBlock(cstype, csname2, cstext2.ToString(), False)
      
    End If
    
  End Sub
  
</script>

<html xmlns="http://www.w3.org/1999/xhtml" >
  <head>
    <title>ClientScriptManager Example</title>
  </head>
  <body>
     <form id="Form1"
         runat="server">
        <input type="text" id="Message" /> <input type="button" value="ClickMe" onclick="DoClick()" />
     </form>
  </body>
</html>

Observações

Chame este método antes de o RegisterStartupScript chamar para evitar registar scripts duplicados. Isto é particularmente importante se o script requer uma grande quantidade de recursos do servidor para ser criado.

Um script de arranque de cliente é identificado de forma única pela sua chave e pelo seu tipo. Scripts com a mesma chave e tipo são considerados duplicados.

Ver também

Aplica-se a

IsStartupScriptRegistered(String)

Determina se o script de arranque está registado com o Page objeto usando a chave especificada.

public:
 bool IsStartupScriptRegistered(System::String ^ key);
public bool IsStartupScriptRegistered(string key);
member this.IsStartupScriptRegistered : string -> bool
Public Function IsStartupScriptRegistered (key As String) As Boolean

Parâmetros

key
String

A chave do script de arranque a procurar.

Devoluções

true se o script de arranque estiver registado; caso contrário, false.

Observações

Chame este método antes de o RegisterStartupScript chamar para evitar registar scripts duplicados. Isto é particularmente importante se o script requer uma grande quantidade de recursos do servidor para ser criado.

Um script de arranque é identificado de forma única pela sua chave e pelo seu tipo. Scripts com a mesma chave e tipo são considerados duplicados.

Esta sobrecarga do IsStartupScriptRegistered método chama a sobrecarga que recebe tanto uma cadeia key como um type parâmetro com o tipo definido como Page objeto

Ver também

Aplica-se a