Aracılığıyla paylaş


ClientScriptManager.RegisterClientScriptBlock Yöntem

Tanım

İstemci betiğini nesnesine Page kaydeder.

Aşırı Yüklemeler

RegisterClientScriptBlock(Type, String, String)

Bir tür, anahtar ve betik değişmez değeri kullanarak istemci betiğini nesnesine Page kaydeder.

RegisterClientScriptBlock(Type, String, String, Boolean)

İstemci betiğini nesneye Page kaydederken betik etiketlerinin eklenip eklenmeyeceğini belirten bir tür, anahtar, betik değişmez değeri ve Boole değeri kullanılır.

RegisterClientScriptBlock(Type, String, String)

Bir tür, anahtar ve betik değişmez değeri kullanarak istemci betiğini nesnesine Page kaydeder.

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)

Parametreler

type
Type

Kaydedilecek istemci betiğinin türü.

key
String

Kaydedilecek istemci betiğinin anahtarı.

script
String

Kaydedilecek istemci betiği değişmez değeri.

Örnekler

Aşağıdaki kod örneği yönteminin RegisterClientScriptBlock kullanımını gösterir.

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

Açıklamalar

İstemci betiği, anahtarı ve türüyle benzersiz bir şekilde tanımlanır. Aynı anahtara ve türe sahip betikler yinelenen olarak kabul edilir. Belirli bir türe ve anahtar çifte sahip yalnızca bir betik sayfaya kaydedilebilir. Zaten kaydedilmiş bir betiği kaydetmeye çalışmak, betiğin bir kopyasını oluşturmaz.

IsClientScriptBlockRegistered Belirli bir anahtar ve tür çiftine sahip bir istemci betiğinin zaten kayıtlı olup olmadığını belirlemek ve gereksiz yere betiği eklemeye çalışmaktan kaçınmak için yöntemini çağırın.

yönteminin RegisterClientScriptBlock bu aşırı yüklemesinde, parametresinde script sağlanan betiğin bir <script> öğe bloğunda sarmalandığından emin olmanız gerekir.

yöntemi, RegisterClientScriptBlock işlenen sayfanın en üstüne bir betik bloğu ekler. Betik bloklarının kaydedildikleri sırayla çıkış olacağı garanti edilmez. Betik bloklarının sırası önemliyse, betikleri tek bir dizede bir araya getirmek için bir StringBuilder nesnesi kullanın ve sonra hepsini tek bir istemci betik bloğuna kaydedin.

Ayrıca bkz.

Şunlara uygulanır

RegisterClientScriptBlock(Type, String, String, Boolean)

İstemci betiğini nesneye Page kaydederken betik etiketlerinin eklenip eklenmeyeceğini belirten bir tür, anahtar, betik değişmez değeri ve Boole değeri kullanılır.

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)

Parametreler

type
Type

Kaydedilecek istemci betiğinin türü.

key
String

Kaydedilecek istemci betiğinin anahtarı.

script
String

Kaydedilecek istemci betiği değişmez değeri.

addScriptTags
Boolean

Betik etiketleri eklenip eklenmeyeceğini belirten boole değeri.

Özel durumlar

İstemci betiği blok türü şeklindedir null.

Örnekler

Aşağıdaki kod örneği yönteminin RegisterClientScriptBlock kullanımını gösterir. parametresinin addScriptTags olarak ayarlandığını true , dolayısıyla başlangıç ve kapanış betik etiketlerinin parametreye script dahil edilmediğini unutmayın.

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

Açıklamalar

İstemci betiği, anahtarı ve türüyle benzersiz bir şekilde tanımlanır. Aynı anahtara ve türe sahip betikler yinelenen olarak kabul edilir. Belirli bir türe ve anahtar çifte sahip yalnızca bir betik sayfaya kaydedilebilir. Zaten kaydedilmiş bir betiği kaydetmeye çalışmak, betiğin bir kopyasını oluşturmaz.

IsClientScriptBlockRegistered Belirli bir anahtar ve tür çiftine sahip bir istemci betiğinin zaten kayıtlı olup olmadığını belirlemek için yöntemini çağırın. Bu, betiği gereksiz yere eklemeye çalışmamanızı sağlar.

yönteminin RegisterClientScriptBlock bu aşırı yüklemesinde, parametresinde sağlanan betiğin script parametresini kullanarak addScriptTags bir <script> öğe bloğuyla sarmalanıp sarmalanmayacağını belirtebilirsiniz. ayarı addScriptTags true , betik etiketlerinin otomatik olarak ekleneceğini gösterir.

yöntemi, RegisterClientScriptBlock işlenen sayfanın en üstüne bir betik bloğu ekler. Betik bloklarının kaydedildikleri sırayla çıkış olacağı garanti edilmez. Betik bloklarının sırası önemliyse, betikleri tek bir dizede bir araya getirmek için bir StringBuilder nesnesi kullanın ve sonra hepsini tek bir istemci betik bloğuna kaydedin.

Ayrıca bkz.

Şunlara uygulanır