AspxコントロールからJavaScript関数を呼び出したいのですが。たとえば、私が持っていたとしましょう:
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>Untitled Page</title>
<script type="text/javascript">
function test(x, y)
{
}
</script>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:Button ID="Button1" runat="server" Text="Button"
onclick="Button1_Click"/>
</div>
</form>
</body>
</html>
そして後ろのコードで:
protected void Button1_Click(object sender, EventArgs e)
{
// do stuff (really going to a database to fill x and y)
int[] x = new int[] { 1, 2, 3, 4, 5 };
int[] y = new int[] { 1, 2, 3, 4, 5 };
// call javascript function as test(x,y);
}
それを行う方法はありますか?
Page.ClientScript.RegisterStartupScript メソッドを使用できます。
ScriptManagerまたは任意のAjaxコントロール/非同期ポストバックを使用している場合は、 ScriptManager.RegisterStartupScript メソッドを確認してください。
編集:
実際、必要な関数はおそらく ScriptManager.RegisterClientScriptBlock です。
私が見つけた他のいくつかのこと:
次のような配列を直接渡すことはできません。
this.Page.ClientScript.RegisterClientScriptBlock(this.GetType(), "xx",
"<script>test("+x+","+y+");</script>");
これは、 "System.Int32 []"を返すxとyのToString()メソッドを呼び出し、JavaScriptは明らかにそれを使用できないためです。 「[1,2,3,4,5]」のように配列を文字列として渡す必要があったため、変換を行うヘルパーメソッドを作成しました。
また、this.Page.ClientScript.RegisterStartupScript()とthis.Page.ClientScript.RegisterClientScriptBlock()の間には違いがあります。前者はページの下部にスクリプトを配置します。これには、コントロール(document.getElementByIDなど)。 RegisterClientScriptBlock()はタグがレンダリングされる前に実行されるため、そのメソッドを使用すると実際にはJavascriptエラーが発生します。
http://www.wrox.com/WileyCDA/Section/Manipulating-ASP-NET-Pages-and-Server-Controls-with-JavaScript.id-310803.html 2つの違いをカバーかなりよく。
これが私が思いついた完全な例です:
// code behind
protected void Button1_Click(object sender, EventArgs e)
{
int[] x = new int[] { 1, 2, 3, 4, 5 };
int[] y = new int[] { 1, 2, 3, 4, 5 };
string xStr = getArrayString(x); // converts {1,2,3,4,5} to [1,2,3,4,5]
string yStr = getArrayString(y);
string script = String.Format("test({0},{1})", xStr, yStr);
this.Page.ClientScript.RegisterStartupScript(this.GetType(),
"testFunction", script, true);
//this.Page.ClientScript.RegisterClientScriptBlock(this.GetType(),
//"testFunction", script, true); // different result
}
private string getArrayString(int[] array)
{
StringBuilder sb = new StringBuilder();
for (int i = 0; i < array.Length; i++)
{
sb.Append(array[i] + ",");
}
string arrayStr = string.Format("[{0}]", sb.ToString().TrimEnd(','));
return arrayStr;
}
//aspx page
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>Untitled Page</title>
<script type="text/javascript">
function test(x, y)
{
var text1 = document.getElementById("text1")
for(var i = 0; i<x.length; i++)
{
text1.innerText += x[i]; // prints 12345
}
text1.innerText += "\ny: " + y; // prints y: 1,2,3,4,5
}
</script>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:Button ID="Button1" runat="server" Text="Button"
onclick="Button1_Click" />
</div>
<div id ="text1">
</div>
</form>
</body>
</html>
スクリプトマネージャを含む
コードビハインド機能
ScriptManager.RegisterStartupScript(this, this.GetType(), "HideConfirmBox", "javascript:HideAAConfirmBox(); ", true);
Response.Write("<scrip" + "t>test(" + x + "," + y + ");</script>");
vStudio/asp.netコンパイラはスクリプトキーワードを好まないため、スクリプトキーワードを分割する
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>Call Java script function on Code behind</title>
<script type="text/javascript">
function abc()
{
var a=20;
var b=30;
alert("you enter"+a+":"+b);
}
</script>
</head>
csコード
protected void Page_Load(object sender, EventArgs e)
{
TextBox2.Attributes.Add("onkeypress", "return abc();");
}
これを試して
サーバー上でJavascriptを処理することに関心がある場合は、新しいオープンソースライブラリと呼ばれる- Jint これにより、サーバー側のJavascriptを実行できます。基本的には、C#で記述されたJavascriptインタープリターです。私はそれをテストしており、これまでのところかなり有望に見えます。
これはサイトからの説明です:
他のスクリプトエンジンとの違い:
Jintは、内部でコンパイルを使用しているCodeDomProvider手法を使用していないため、コンパイル済みのアセンブリをアンロードできないため、メモリリークが発生するため、異なります。さらに、この手法を使用すると、JavaScriptのように動的に型変数を使用することができなくなり、スクリプトの柔軟性が高まります。反対に、Jintは独自の解析ロジックを埋め込み、スクリプトを実際に解釈します。 Jintはこの目的のために有名なANTLR( http://www.antlr.org )ライブラリを使用しています。言語としてJavascriptを使用しているため、新しい言語を習得する必要はありません。スクリプト作成の目的で非常に強力であることが実証されており、構文チェックにいくつかのテキストエディターを使用できます。
<head>
<script type="text/javascript">
function test(x, y)
{
var cc = "";
for (var i = 0; i < x.length; i++)
{
cc += x[i];
}
cc += "\ny: " + y;
return cc;
}
</script>
</head>
<body>
<form id="form1" runat="server">
<asp:Button ID="Button1" runat="server" Text="Button" />
<p>
<asp:TextBox ID="TextBox1" Name="TextBox1" runat="server" AutoPostBack="True" TextMode="MultiLine"></asp:TextBox>
</p>
</form>
</body>
protected void Page_Load(object sender, EventArgs e)
{
int[] x = new int[] { 1, 2, 3, 4, 5 };
int[] y = new int[] { 1, 2, 3, 4, 5 };
string xStr = getArrayString(x); // converts {1,2,3,4,5} to [1,2,3,4,5]
string yStr = getArrayString(y);
string script = String.Format(" var y = test({0},{1}) ; ", xStr, yStr);
script += String.Format(" document.getElementById(\"TextBox1\").value = y ");
this.Page.ClientScript.RegisterStartupScript(this.GetType(), "testFunction", script, true);
// this.Page.ClientScript.RegisterClientScriptBlock(this.GetType(), "testFunction", script, true); // different result
}
private string getArrayString(int[] array)
{
StringBuilder sb = new StringBuilder();
for (int i = 0; i < array.Length; i++)
{
sb.Append(array[i] + ",");
}
string arrayStr = string.Format("[{0}]", sb.ToString().TrimEnd(','));
return arrayStr;
}
私はあなたがポストバックの後でブラウザではなくJavaScriptサーバーサイドを実行したいと思いますよね?
私の知る限りそれは不可能です
ポストバック後に実行したいだけの場合は、次のようにすることができます。
this.Page.ClientScript.RegisterClientScriptBlock(this.GetType(), "xx", "<script>test("+x+","+y+");</script>");