JSONResultから文字列リストを解凍できないようです。
コントローラは次のとおりです。
[HttpPost]
public JsonResult GetDescriptions(string incomingProjectName)
{
List<string> result = new List<string>();
using (SFEntities ctx = new SFEntities())
{
result = (from ct in ctx.SF_CLIENT_TASK
join cp in ctx.SF_CLIENT_PROJECT on ct.PROJECT equals cp.ID
where cp.NAMEX == incomingProjectName
select ct.DESCRIPTION).ToList();
}
return Json( result );
}
そして、これが私のajaxメソッドです:
$.ajax({
type: "POST",
url: "Home/GetDescriptions",
contentType: "application/json; charset=utf-8",
data: '{incomingProjectName : "projName"}',
dataType: "json",
success: function (msg) {
alert("msg: " + msg); // [Object object]
alert("msg: 2 string: " + msg.toString); // function toString() { [native code] }
var list = eval(msg);
alert("list: " + list); // blank
alert("list to string: " + list.toString); // function toString() { [native code] }
alert("list data: " + list.valueOf); // valueOf() { [native code] }
alert("msg[0]: " + msg[0]); // undefined
alert("list[0]: " + list[0]); // undefined
},
});
デバッガーでは、結果の内容に項目の長いリストが含まれていることがわかりますが、JavaScriptでアクセスしようとすると、表示されません。
呼び出せない、ある種の逆シリアル化または抽出メソッドはありますか?
編集:これは定型的なものでなければならないようですが、私は何らかの理由でこれを行う多くの例をグーグルで検索することができませんでした...
編集:これが私の最終的な(動作中の)コードです:
$.ajax({
type: "POST",
url: "Home/GetDescriptions",
data: { incomingProjectName: projName },
success: function (msg) {
alert( "msg: " + msg );
},
error: function (msg) {
alert("Failed: " + msg.status + ": " + msg.statusText);
}
そしてここにコントローラーコードがあります:
public JsonResult GetDescriptions(string incomingProjectName)
{
List<string> result = new List<string>();
using (SFEntities ctx = new SFEntities())
{
result = (from ct in ctx.SF_CLIENT_TASK
join cp in ctx.SF_CLIENT_PROJECT on ct.PROJECT equals cp.ID
where cp.NAMEX == incomingProjectName
select ct.DESCRIPTION).ToList();
}
return Json( result );
}