我试图将公共字典从c#传递到asp.net。
这是我的代码:
代码背后:
public Dictionary<string, List<string>> dict = new Dictionary<string, List<string>>();
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
RetrieveDataField();
}
}
void RetrieveDataField()
{
DataDefinitionResponse[] _dr = _service.DataDefinitionList(_companyID);
DataTable dt = new DataTable();
dt.Columns.Add("Name");
dt.Columns.Add("Type");
foreach (DataDefinitionResponse dr in _dr)
{
if (dr.Type != "Group" && dr.Type != "File")
{
DataRow row = dt.NewRow();
row["Name"] = dr.Name;
row["Type"] = dr.Type;
dt.Rows.Add(row);
if (dr.Type == "Dropdown")
{
string[] strSplit = dr.ListValue.Split('|');
List<string> lst = new List<string>();
foreach (string word in strSplit)
{
lst.Add(word);
}
dict.Add(dr.Name, lst);
}
}
}
ddlFieldName.DataSource = dt;
ddlFieldName.DataTextField = "Name";
ddlFieldName.DataValueField = "Type";
ddlFieldName.DataBind();
}
ASP:
<script type="text/javascript">
$(document).ready(function () {
alert(<%=dict%>); //Error here
$("#MainContent_ddlFieldName").live("change", function () {
$.ajax({
type: "POST",
url: "WebService/WebFunction.asmx/PopulateDropdown",
data: "{'dict': '" + 'a' + "'}",
contentType: 'application/json; charset=utf-8',
dataType: 'json',
success: function (data) {
// data.d;
// $("#txtBLShipperContactNo").val(data.d);
alert(data.d);
},
error: function (XMLHttpRequest, textStatus, errorThrown) {
alert("Error Shipper: " + errorThrown);
}
});
});
});
</script>
有什么想法吗?
答案 0 :(得分:4)
当您使用<%=dict%>
时,编译器正在执行默认的ToString()方法,因此您可以获得类似alert(System.Collections.Generic.Dictionary...);
的内容。请注意,此处没有引号,因此会生成javascript错误。您可以通过在引号中包围它来“修复”此问题:alert("<%=dict%>");
。
然而,这可能不是你想要做的。您很可能正在尝试将实际字典放入Javascript对象中。为此,您可以使用javascript的JSON.parse
和System.Web.Script.Serialization.JavaScriptSerializer
将数据输出为JSON对象。如果您正在使用jQuery,那么您可以使用parseJSON,否则您可以在大多数浏览器上使用JSON.parse,我认为(我总是使用jQuery,所以我比浏览器提供的JSON.parse更熟悉它。)
以下是将对象输出到JSON的一些代码:
public string DictJSON
{
get {
JavaScriptSerializer jSer = new JavaScriptSerializer();
return jSer.Serialize(dict);
}
}
以下是使用jQuery的方式:
$.parseJSON('<%=DictJSON %>');
请注意,JavaScriptSerializer是System.Web.Extensions.dll的一部分,因此您需要添加对它的引用。它不能处理所有对象类型,但是Dictionary应该没问题,List也应该如此。此外,由于它以双引号输出JSON对象字符串,因此请确保在parseJSON中使用单引号。
答案 1 :(得分:1)
我真的不知道你的代码产生的错误,但这就是我所知道的。应该添加字典或'binded',如下所示:
DataTable dt = new DataTable();
Dictionary<string,string> dict = new Dictionary<string,string>();
dt.Columns.Add(new DataColumn("Name", typeof(string)));
dt.Columns.Add(new DataColumn("Type", typeof(string)));
foreach (DataDefinitionResponse dr in _dr)
{
if (dr.Type != "Group" && dr.Type != "File")
{
DataRow row = dt.NewRow();
row["Name"] = dr["Name"].toString();
row["Type"] = dr["Key"].toString;
dt.Rows.Add(row);
}
}
foreach(DataRow dr in dt.Rows)
{
dict.Add(dr.ItemArray[0].ToString(), dr.ItemArray[1].ToString());
}
ddlFieldName.DataSource = dict; // the dictionary should be here
ddlFieldName.DataTextField = "Key";
ddlFieldName.DataValueField = "Value";
ddlFieldName.DataBind();
或者在第一个foreach循环中添加Dictionary元素,如下所示:
foreach (DataDefinitionResponse dr in _dr)
{
if (dr.Type != "Group" && dr.Type != "File")
{
DataRow row = dt.NewRow();
row["Name"] = dr["Name"].toString();
row["Type"] = dr["Key"].toString();
dt.Rows.Add(row);
dict.Add(dr["Key"].ToString(), dr["Name"].ToString());
}
}
ddlFieldName.DataSource = dict; // the dictionary should be here
ddlFieldName.DataTextField = "Key";
ddlFieldName.DataValueField = "Value";
ddlFieldName.DataBind();
<强>更新强>
您正在以错误的方式声明或初始化列。您可以尝试我的更新。