Sdílet prostřednictvím


ClientScriptManager.RegisterClientScriptBlock Metoda

Definice

Zaregistruje klientský skript s objektem Page .

Přetížení

RegisterClientScriptBlock(Type, String, String)

Zaregistruje klientský skript s objektem Page pomocí typu, klíče a literálu skriptu.

RegisterClientScriptBlock(Type, String, String, Boolean)

Zaregistruje klientský skript s objektem Page pomocí typu, klíče, literálu skriptu a logické hodnoty označující, zda se mají přidat značky skriptu.

RegisterClientScriptBlock(Type, String, String)

Zaregistruje klientský skript s objektem Page pomocí typu, klíče a literálu skriptu.

public:
 void RegisterClientScriptBlock(Type ^ type, System::String ^ key, System::String ^ script);
public void RegisterClientScriptBlock (Type type, string key, string script);
member this.RegisterClientScriptBlock : Type * string * string -> unit
Public Sub RegisterClientScriptBlock (type As Type, key As String, script As String)

Parametry

type
Type

Typ klientského skriptu, který se má zaregistrovat.

key
String

Klíč klientského skriptu, který se má zaregistrovat.

script
String

Literál klientského skriptu, který se má zaregistrovat.

Příklady

Následující příklad kódu ukazuje použití RegisterClientScriptBlock metody.

<%@ 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 script on the page.
    String csName = "ButtonClickScript";
    Type csType = this.GetType();

    // Get a ClientScriptManager reference from the Page class.
    ClientScriptManager cs = Page.ClientScript;

    // Check to see if the client script is already registered.
    if (!cs.IsClientScriptBlockRegistered(csType, csName))
    {
      StringBuilder csText = new StringBuilder();
      csText.Append("<script type=\"text/javascript\"> function DoClick() {");
      csText.Append("Form1.Message.value='Text from client script.'; }");
      csText.Append("</script>");
      cs.RegisterClientScriptBlock(csType, csName, csText.ToString());
    }
  }
</script>
<html  >
  <head>
    <title>RegisterClientScriptBlock 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">
    Public Sub Page_Load(ByVal sender As [Object], ByVal e As EventArgs)
        ' Define the name and type of the client script on the page. 
        Dim csName 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 client script is already registered. 
        If Not cs.IsClientScriptBlockRegistered(csType, csName) Then
            Dim csText As New StringBuilder()
            csText.Append("<script type=""text/javascript""> function DoClick() {")
            csText.Append("Form1.Message.value='Text from client script.'; }")
            csText.Append("</script>")
            cs.RegisterClientScriptBlock(csType, csName, csText.ToString())
        End If
    End Sub
</script>
<html  >
  <head>
    <title>RegisterClientScriptBlock Example</title>
  </head>
  <body>
     <form id="Form1"
         runat="server">
        <input type="text" id="Message" /> <input type="button" value="ClickMe" onclick="DoClick()" />
     </form>
  </body>
</html>

Poznámky

Klientský skript je jedinečně identifikován svým klíčem a typem. Skripty se stejným klíčem a typem se považují za duplicitní. Na stránce je možné zaregistrovat pouze jeden skript s daným typem a párem klíčů. Pokus o registraci již zaregistrovaného skriptu nevytvoří duplikát skriptu.

Voláním IsClientScriptBlockRegistered metody určete, zda je již zaregistrovaný klientský skript s daným párem klíč a typ, a vyhněte se zbytečnému pokusu o přidání skriptu.

Při tomto přetížení RegisterClientScriptBlock metody se musíte ujistit, že skript zadaný v parametru script je zabalen do bloku elementu <script> .

Metoda RegisterClientScriptBlock přidá blok skriptu na začátek vykreslené stránky. Bloky skriptů nejsou zaručené, že budou výstupem v pořadí, v jakém jsou registrovány. Pokud je pořadí bloků skriptů důležité, pomocí objektu StringBuilder shromážděte skripty do jednoho řetězce a pak je všechny zaregistrujte v jednom bloku klientských skriptů.

Viz také

Platí pro

RegisterClientScriptBlock(Type, String, String, Boolean)

Zaregistruje klientský skript s objektem Page pomocí typu, klíče, literálu skriptu a logické hodnoty označující, zda se mají přidat značky skriptu.

public:
 void RegisterClientScriptBlock(Type ^ type, System::String ^ key, System::String ^ script, bool addScriptTags);
public void RegisterClientScriptBlock (Type type, string key, string script, bool addScriptTags);
member this.RegisterClientScriptBlock : Type * string * string * bool -> unit
Public Sub RegisterClientScriptBlock (type As Type, key As String, script As String, addScriptTags As Boolean)

Parametry

type
Type

Typ klientského skriptu, který se má zaregistrovat.

key
String

Klíč klientského skriptu, který se má zaregistrovat.

script
String

Literál klientského skriptu, který se má zaregistrovat.

addScriptTags
Boolean

Logická hodnota označující, zda se mají přidat značky skriptu.

Výjimky

Typ bloku klientského skriptu je null.

Příklady

Následující příklad kódu ukazuje použití RegisterClientScriptBlock metody. Všimněte si addScriptTags , že parametr je nastavený na true , takže značky počátečního a koncového skriptu nejsou součástí parametru script .

<%@ 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>

Poznámky

Klientský skript je jedinečně identifikován svým klíčem a typem. Skripty se stejným klíčem a typem se považují za duplicitní. Na stránce je možné zaregistrovat pouze jeden skript s daným typem a párem klíčů. Pokus o registraci již zaregistrovaného skriptu nevytvoří duplikát skriptu.

Voláním IsClientScriptBlockRegistered metody zjistěte, zda je již zaregistrovaný klientský skript s daným párem klíč a typ. Díky tomu se můžete vyhnout zbytečnému pokusu o přidání skriptu.

V tomto přetížení RegisterClientScriptBlock metody můžete pomocí parametru určit, zda je skript zadaný v parametru script zabalen s blokem <script> elementu addScriptTags . Nastavení addScriptTags na true označuje, že značky skriptů budou přidány automaticky.

Metoda RegisterClientScriptBlock přidá blok skriptu na začátek vykreslené stránky. Bloky skriptů nejsou zaručené, že budou výstupem v pořadí, v jakém jsou registrovány. Pokud je pořadí bloků skriptů důležité, pomocí objektu StringBuilder shromážděte skripty do jednoho řetězce a pak je všechny zaregistrujte v jednom bloku klientských skriptů.

Viz také

Platí pro