加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 如何遍历从JsonResult方法返回的Dictionary?

发布时间:2020-12-16 02:00:20 所属栏目:百科 来源:网络整理
导读:我有一个 JavaScript方法,它对控制器方法进行AJAX调用. 此控制器方法是一个JsonResult方法,它将字典对象返回给我的JavaScript.但是我对这个对象做的任何事情(比如,dictionaryObject.count,dictionaryObejct [i] .value等)给了我“undefined”.有关如何使用此
我有一个 JavaScript方法,它对控制器方法进行AJAX调用.
此控制器方法是一个JsonResult方法,它将字典对象返回给我的JavaScript.但是我对这个对象做的任何事情(比如,dictionaryObject.count,dictionaryObejct [i] .value等)给了我“undefined”.有关如何使用此对象的任何想法?

function MakeControllerMethodCallFunction(stringParam1,stringParam2) {
    // Remove all rows from table so that table can have latest data
    $('#TableModal tr').each(function (i,row) {
        var $row = $(row);

        $row.remove();
    });

    $("#TableModal thead").append("<tr><th>" + stringParam1+ " Details " + "</th></tr>");

    //Resolving the server side method URL
    var websitePath = GetRootWebSitePath();
    var getUrl = websitePath + "/Home/GetDetails";

    //Creating parameters for Ajax call
    var params = "{"ParamOne" : "" + stringParam1+ "","ParamTwo" : "" + stringParam2+ "" }";

    //AJAX Call
    $.ajax({
        url: getUrl,type: 'POST',dataType: 'json',contentType: 'application/json; charset=utf-8',data: params,success: MakeControllerMethodCallFunction_Success,error: function (xhr,status,thrownError) {
            alert("Get Details error");
        }
    });
}

//On Success of MakeControllerMethodCallFunction() this will be hit and values will be bind to the table
function MakeControllerMethodCallFunction_Success(dictionaryObject) {
    var Size = 0;
    if (dictionaryObject!= null) {

        Size = (dictionaryObject!= null) ? dictionaryObject.count : 0;
    }

    if (Size != null) {

        for (var i = 0; i < Size; i++) {

            var newRow = "<tr>";

            if (dictionaryObject!= null && dictionaryObject.count> 0 && dictionaryObject[i] != null) {
                newRow += "<td>" + dictionaryObject[i].name + "</td>" + "<td>" + dictionaryObject[i].value + "</td>";

            }
            else {
                newRow += "<td></td>";
            }
            newRow += "</tr>";
            $("#TableModal tbody").append(newRow);
        }
    }
}

解决方法

假设您已返回Dictionary< string,string>来自你的控制器动作:

public ActionResult GetDetails()
{
    var result = new Dictionary<string,string>
    {
        { "key1","value1" },{ "key2","value2" },{ "key3","value3" },};

    return Json(result,JsonRequestBehavior.AllowGet);
}

这将导致通过网络发送以下JSON:

{"key1":"value1","key2":"value2","key3":"value3"}

如您所见,这并不代表javascript Array,因此没有计数,大小或长度.这只是一个具有属性的普通javascript对象.

以下是如何使用AJAX成功回调中的值:

function MakeControllerMethodCallFunction_Success(dictionaryObject) {
    for (var key in dictionaryObject) {
        if (dictionaryObject.hasOwnProperty(key)) {
            var value = dictionaryObject[key];
            alert(key + " -> " + value);
        }
    }
}

假设您返回了Dictionary< string,SomeModel>您显然可以在javascript:value.SomeProperty中的值变量上访问此模型的属性.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读