ClientScriptManager.RegisterClientScriptBlock Metoda
Definice
Důležité
Některé informace platí pro předběžně vydaný produkt, který se může zásadně změnit, než ho výrobce nebo autor vydá. Microsoft neposkytuje žádné záruky, výslovné ani předpokládané, týkající se zde uváděných informací.
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ů.