尝试将对象强制转换为javascript [] {} - C#键值集合或字典<string,object>或<string,string =“”> </string,> </string,object>

时间:2012-12-26 23:20:36

标签: c# javascript jquery asp.net ajax

我想更好地理解将对象转换为名称与值集合的问题

说...就好像我可以这样做

1) java脚本需要一些微调吗?打包数据..

2)对我来说最重要的是:从该键值Js转换为Dictionary<T,T> C#的正确方法是什么?

Aspx / Html部分

<input type="text" id="tbx_Name" value="Avi" />
<input type="text" id="tbx_City" value="TelAviv" />
<input type="text" id="tbx_Country" value="Israel" />

<select id="ChosenRandomClass" style="display:none">
<option selected="selected" value="0">(choose a random)</option>
<option value="1">random Top Beach</option>
<option value="2">random Top Center</option>
<option value="3">random Local Pub</option>
</select>

JavaScript / jQuery部分

  function AddNew() {

        if (!confirm("would you like to add this contact ?")) return;

        var Name = $('#tbx_Name').val();
        var City = $('#tbx_City').val();
        var Country = $('#tbx_Country').val();

        var selectedRC = $('#ChosenRandomClass option:selected').val();

        var hDate = []

        var param1 = { key: "Name", value: Name };
        var param2 = { key: "City", value: City };
        var param3 = { key: "Country", value: Country };
        var param4 = { key: "SelctedClass", value: selectedRC };

        hDate.push(param1);
        hDate.push(param2);
        hDate.push(param3);
        hDate.push(param4);
                                         // is this part necessary the data will not get to
                                         // code behind properly without the serializing ?
        var startPrt = Sys.Serialization.JavaScriptSerializer.serialize(hDate);
              ajaxUpdate("addNew", startPrt);

    }

Code behind C#部分

 
public void AddNewRecord(object startPrt)
{
    Dictionary<string, string> SenthDate = new Dictionary<string, string>();
   //        .....etc

}

我将欣赏正确的答案

谢谢你的帮助和时间。

2 个答案:

答案 0 :(得分:2)

我试了一下你的样品,注意到 startPrt 参数实际上是作为字典的数组接收的(字符串,对象) 。因此,如果你像这样进行AJAX调用:

var hDate = [];
hDate.push({ key: "Name", value: Name });
hDate.push({ key: "City", value: City });
hDate.push({ key: "Country", value: Country });
hDate.push({ key: "SelctedClass", value: selectedRC });

$.ajax({
    contentType: 'application/json; charset=utf-8',
    url: 'MyPage.aspx/AddNewRecord',
    type: 'POST',
    data: JSON.stringify({ startPrt: hDate }),
    success: success, // success callback
    error: error // error callback
});

您可以定义 WebMethod ,如下所示将 startPrt 参数转换为字典:

[WebMethod]
public static void AddNewRecord(object startPrt)
{
    var dict = new Dictionary<string, object>();
    foreach (Dictionary<string, object> pair in (Array)startPrt)
        dict.Add((string)pair["key"], pair["value"]);
}

答案 1 :(得分:0)

传统的方法是构造一个普通的javascript对象,jQuery.ajax(...)可以使用它而无需任何预处理。

var hDate = {
    "Name": $('#tbx_Name').val(),
    "City": $('#tbx_City').val(),
    "Country": $('#tbx_Country').val(),
    "SelctedClass": $('#ChosenRandomClass').val()
};
ajaxUpdate("addNew", hDate);

ajaxUpdate()中,ajax表达式将是这样的:

function ajaxUpdate(action, data) {
    ...
    $.ajax({
        url: '...',
        data: data,
        ...
        success: function(){
            ...
        }
    });
}

因此,序列化数据将可用于任何风格的服务器端脚本。