Algunas otras cosas que descubrí:
No se puede pasar directamente de una matriz como:
this.Page.ClientScript.RegisterClientScriptBlock(this.GetType(), "xx",
"<script>test("+x+","+y+");</script>");
debido a que llama al ToString() de X e Y, que devuelve "System.Int32 []", y obviamente Javascript no puede utilizar ese . Tuve que pasar las matrices como cadenas, como "[1,2,3,4,5]", así que escribí un método de ayuda para hacer la conversión.
Además, existe una diferencia entre this.Page.ClientScript.RegisterStartupScript() y this.Page.ClientScript.RegisterClientScriptBlock() - el primero coloca la secuencia de comandos en la parte inferior de la página, que necesito para poder poder acceder a los controles (como con document.getElementByID). RegisterClientScriptBlock() se ejecuta antes de que se procesen las etiquetas, por lo que en realidad obtengo un error de Javascript si uso ese método.
http://www.wrox.com/WileyCDA/Section/Manipulating-ASP-NET-Pages-and-Server-Controls-with-JavaScript.id-310803.html cubre la diferencia entre los dos bastante bien.
Aquí está el ejemplo completo que se me ocurrió:
// 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>
Esta pregunta es similar, pero no es lo mismo. En mi pregunta, estoy siendo más específico acerca de cómo pasar argumentos a la función de JavaScript y el suministro de código de ejemplo. Estoy interesado en la mecánica específica de eso. –