我想通過JavaScript數組到C#代碼後面使用Ajax回發。但是當我嘗試這個時它沒有工作。下面我附上了我的代碼。任何人都可以幫助我嗎?傳遞Javascript數組到C#代碼後面使用Ajax POST
Test.aspx的
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="test.aspx.cs" Inherits="hotelbeds.test" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>jQuery UI Tooltip - Custom animation demo</title>
<link rel="stylesheet" href="http://code.jquery.com/ui/1.10.3/themes/smoothness/jquery-ui.css" />
<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
<script src="http://code.jquery.com/ui/1.10.3/jquery-ui.js"></script>
<link rel="stylesheet" href="/resources/demos/style.css" />
<script type="text/javascript">
function testbook(hotelcode) {
alert("clicked");
//var values = {"1","2","3"};
var mycars = new Array();
mycars[0] = "Saab";
mycars[1] = "Volvo";
mycars[2] = "BMW";
var theIds = JSON.stringify(mycars);
alert(theIds);
$.ajax({
type: "POST",
url: "test.aspx/Done",
contentType: "application/json; charset=utf-8",
data: "{ 'ids':'"+ theIds +"'}",
dataType: "json",
success: function (result) {
alert('Yay! It worked!');
},
error: function (result) {
alert('Oh no :(');
}
});
return false;
}
</script>
</head>
<body>
<form id="form1" runat="server">
<div>
</div>
</form>
</body>
</html>
代碼文件
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data.SqlClient;
using System.Web.Services;
using System.Configuration;
using System.Drawing;
namespace hotelbeds
{
public partial class test : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs ea)
{
ImageButton testbtn = new ImageButton();
testbtn.OnClientClick = "return testbook('15000')";
form1.Controls.Add(testbtn);
}
[WebMethod]
public static void done(string[] ids)
{
String[] a = ids;
}
}
}
背後,當我改變的WebMethod下面這工作沒有任何問題。但對我來說這不是有用的。
[WebMethod]
public static void done(string ids)
{
String a = ids;
}