Ajax 成功 returns "undefined" asp.net 核心
Ajax success returns "undefined" in asp.net core
我正在尝试通过 ajax 获取 json 数据并在视图中显示它们。操作方法中的数据是正确的,但是当我想在 table 中显示数据时,所有 s 都显示为未定义,而且我知道有很多行我没有这么多行。也许是因为 for循环和每个循环,但我真的不知道如何修复它。
这是 json 数据:
{
"$id": "1",
"$values": [
{
"$id": "2",
"TicketId": 32,
"Author": "5aff2283-5e71-4b10-a809-7c0235ccc18d",
"To": "f956d006-72b7-4a4c-b5cf-9354d6e6f193",
"Status": 1,
"priority": 2,
"TrackingCode": "1bbdd10553634f2fbab1769cbf0b1b44",
"CreateDate": "2021-04-04T10:10:35.5043873",
"IsPrivate": true,
"IsDeleted": false,
"User": null,
"ApplicationRole": {
"$id": "3",
"Title": "\u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06CC\u0633",
"Description": null,
"IsDelete": false,
"CreateDate": "2021-03-17T12:20:46.6002855",
"EditDate": null,
"ParentId": null,
"Roles": null,
"Id": "f956d006-72b7-4a4c-b5cf-9354d6e6f193",
"Name": "programmer",
"NormalizedName": "PROGRAMMER",
"ConcurrencyStamp": "a76600ef-8e82-4479-915d-41ad750cad5d"
},
"Answer": null
},
{
"$id": "4",
"TicketId": 33,
"Author": "5aff2283-5e71-4b10-a809-7c0235ccc18d",
"To": "f956d006-72b7-4a4c-b5cf-9354d6e6f193",
"Status": 2,
"priority": 0,
"TrackingCode": "f316a0d4bf9c4014a8acce1c152a56de",
"CreateDate": "2021-04-04T10:15:09.7256989",
"IsPrivate": false,
"IsDeleted": false,
"User": null,
"ApplicationRole": {
"$ref": "3"
},
"Answer": {
"$id": "5",
"AnswerId": 6,
"TicketId": 33,
"UserId": "5aff2283-5e71-4b10-a809-7c0235ccc18d",
"AnswerText": "\u003Cp\u003Ebbbbbb\u003C/p\u003E\r\n",
"File": null,
"DateTime": "2021-04-05T11:03:24.6079034",
"IsDeleted": false,
"Ticket": {
"$ref": "4"
},
"User": null
}
}
]
}
这是Ajax:
<script type="text/javascript">
$(document).ready(function () {
loadData();
});
function loadData() {
$.ajax({
url: "/Ticket/GetMyTickets",
type: "Get",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (ListData) {
var str = "";
for (var i = 0; i < ListData.length; i++) {
$.each(ListData[i], function (index, items) {
str += "<tr>";
str += "<td>" + ListData[i].Status + "</td>";
str += "<td>" + ListData[i].priority + "</td>";
str += "<td>" + ListData[i].TrackingCode + "</td>";
str += "<td>" + ListData[i].CreateDate + "</td>";
str += "<td>" + ListData[i].IsPrivate + "</td>";
str += "<td>" + ListData[i].To + "</td>";
str += "<td><a onclick=Edit(this) data-toggle='modal' data-
target='#myModal'>نمایش پاسخ ها</a></td>";
str += "</tr>";
},
BodyData.innerHTML = str);
$(".TblData tr").fadeIn(1000);
};
}
});
}
我搜索了很多,但没有找到解决问题的方法。
更新
这是 console.log(ListData):
的输出
{
"$id": "1",
"$values": [
{
"$id": "2",
"TicketId": 33,
"Author": "5aff2283-5e71-4b10-a809-7c0235ccc18d",
"To": "f956d006-72b7-4a4c-b5cf-9354d6e6f193",
"Status": 2,
"priority": 0,
"TrackingCode": "f316a0d4bf9c4014a8acce1c152a56de",
"CreateDate": "2021-04-04T10:15:09.7256989",
"IsPrivate": false,
"IsDeleted": false,
"User": {
"$id": "3",
"FullName": "\u0645\u062F\u06CC\u0631 \u0633\u0627\u06CC\u062A",
"Avatar": "DefualtAvatar.jpg",
"IsDelete": false,
"CreateDate": "2021-03-16T13:05:20.6549686",
"EditDate": null,
"Id": "5aff2283-5e71-4b10-a809-7c0235ccc18d",
"UserName": "09876543210",
"NormalizedUserName": "09876543210",
"Email": "nikitmb2@gmail.com",
"NormalizedEmail": null,
"EmailConfirmed": false,
"PasswordHash":
"AQAAAAEAACcQAAAAEFbvXk/J1tXDz/
gAkIwWVjGWwSCeVhRgpPM0PVaRt1NJ1xlNr8HhxtMNWgd2u40BQw==",
"SecurityStamp": "IELKDSXBF5RE3MFHN7CNVOIGWWMK4QAV",
"ConcurrencyStamp": "517cf6f0-2f41-44a6-9a99-9512e0ffc471",
"PhoneNumber": "09876543210",
"PhoneNumberConfirmed": false,
"TwoFactorEnabled": false,
"LockoutEnd": null,
"LockoutEnabled": true,
"AccessFailedCount": 0
},
"ApplicationRole": {
"$id": "4",
"Title": "\u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06CC\u0633",
"Description": null,
"IsDelete": false,
"CreateDate": "2021-03-17T12:20:46.6002855",
"EditDate": null,
"ParentId": null,
"Roles": null,
"Id": "f956d006-72b7-4a4c-b5cf-9354d6e6f193",
"Name": "programmer",
"NormalizedName": "PROGRAMMER",
"ConcurrencyStamp": "a76600ef-8e82-4479-915d-41ad750cad5d"
},
"Answer": {
"$id": "5",
"AnswerId": 6,
"TicketId": 33,
"UserId": "5aff2283-5e71-4b10-a809-7c0235ccc18d",
"AnswerText": "\u003Cp\u003Ebbbbbb\u003C/p\u003E\r\n",
"File": null,
"DateTime": "2021-04-05T11:03:24.6079034",
"IsDeleted": false,
"Ticket": {
"$ref": "2"
},
"User": {
"$ref": "3"
}
}
}
]
}
根据您的 json 结构,您只需要一个循环来遍历 json 数组。因此,只需在 $.each
中使用 ListData["$values"]
,然后使用键名获取相应的值。
演示代码 :
//just for demo
var ListData = {
"$id": "1",
"$values": [{
"$id": "2",
"TicketId": 32,
"Author": "5aff2283-5e71-4b10-a809-7c0235ccc18d",
"To": "f956d006-72b7-4a4c-b5cf-9354d6e6f193",
"Status": 1,
"priority": 2,
"TrackingCode": "1bbdd10553634f2fbab1769cbf0b1b44",
"CreateDate": "2021-04-04T10:10:35.5043873",
"IsPrivate": true,
"IsDeleted": false,
"User": null,
"ApplicationRole": {
"$id": "3",
"Title": "\u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06CC\u0633",
"Description": null,
"IsDelete": false,
"CreateDate": "2021-03-17T12:20:46.6002855",
"EditDate": null,
"ParentId": null,
"Roles": null,
"Id": "f956d006-72b7-4a4c-b5cf-9354d6e6f193",
"Name": "programmer",
"NormalizedName": "PROGRAMMER",
"ConcurrencyStamp": "a76600ef-8e82-4479-915d-41ad750cad5d"
},
"Answer": null
},
{
"$id": "4",
"TicketId": 33,
"Author": "5aff2283-5e71-4b10-a809-7c0235ccc18d",
"To": "f956d006-72b7-4a4c-b5cf-9354d6e6f193",
"Status": 2,
"priority": 0,
"TrackingCode": "f316a0d4bf9c4014a8acce1c152a56de",
"CreateDate": "2021-04-04T10:15:09.7256989",
"IsPrivate": false,
"IsDeleted": false,
"User": null,
"ApplicationRole": {
"$ref": "3"
},
"Answer": {
"$id": "5",
"AnswerId": 6,
"TicketId": 33,
"UserId": "5aff2283-5e71-4b10-a809-7c0235ccc18d",
"AnswerText": "\u003Cp\u003Ebbbbbb\u003C/p\u003E\r\n",
"File": null,
"DateTime": "2021-04-05T11:03:24.6079034",
"IsDeleted": false,
"Ticket": {
"$ref": "4"
},
"User": null
}
}
]
}
$(document).ready(function() {
loadData();
});
function loadData() {
/* $.ajax({
url: "/Ticket/GetMyTickets",
type: "Get",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function(ListData) {*/
var str = "";
//get values array
$.each(ListData["$values"], function(index, items) {
//use items.nameofkey
str += "<tr>";
str += "<td>" + items.Status + "</td>";
str += "<td>" + items.priority + "</td>";
str += "<td>" + items.TrackingCode + "</td>";
str += "<td>" + items.CreateDate + "</td>";
str += "<td>" + items.IsPrivate + "</td>";
str += "<td>" + items.To + "</td>";
str += "<td><a href='#' onclick='Edit(this)' data-toggle='modal' data-target='#myModal'> نمایش پاسخ ها </a></td> ";
str += "</tr>";
});
$(".TblData").html(str)
$(".TblData").fadeIn(1000);
/* };
}
});*/
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<table border="1">
<tbody class="TblData"></tbody>
</table>
我正在尝试通过 ajax 获取 json 数据并在视图中显示它们。操作方法中的数据是正确的,但是当我想在 table 中显示数据时,所有 s 都显示为未定义,而且我知道有很多行我没有这么多行。也许是因为 for循环和每个循环,但我真的不知道如何修复它。 这是 json 数据:
{
"$id": "1",
"$values": [
{
"$id": "2",
"TicketId": 32,
"Author": "5aff2283-5e71-4b10-a809-7c0235ccc18d",
"To": "f956d006-72b7-4a4c-b5cf-9354d6e6f193",
"Status": 1,
"priority": 2,
"TrackingCode": "1bbdd10553634f2fbab1769cbf0b1b44",
"CreateDate": "2021-04-04T10:10:35.5043873",
"IsPrivate": true,
"IsDeleted": false,
"User": null,
"ApplicationRole": {
"$id": "3",
"Title": "\u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06CC\u0633",
"Description": null,
"IsDelete": false,
"CreateDate": "2021-03-17T12:20:46.6002855",
"EditDate": null,
"ParentId": null,
"Roles": null,
"Id": "f956d006-72b7-4a4c-b5cf-9354d6e6f193",
"Name": "programmer",
"NormalizedName": "PROGRAMMER",
"ConcurrencyStamp": "a76600ef-8e82-4479-915d-41ad750cad5d"
},
"Answer": null
},
{
"$id": "4",
"TicketId": 33,
"Author": "5aff2283-5e71-4b10-a809-7c0235ccc18d",
"To": "f956d006-72b7-4a4c-b5cf-9354d6e6f193",
"Status": 2,
"priority": 0,
"TrackingCode": "f316a0d4bf9c4014a8acce1c152a56de",
"CreateDate": "2021-04-04T10:15:09.7256989",
"IsPrivate": false,
"IsDeleted": false,
"User": null,
"ApplicationRole": {
"$ref": "3"
},
"Answer": {
"$id": "5",
"AnswerId": 6,
"TicketId": 33,
"UserId": "5aff2283-5e71-4b10-a809-7c0235ccc18d",
"AnswerText": "\u003Cp\u003Ebbbbbb\u003C/p\u003E\r\n",
"File": null,
"DateTime": "2021-04-05T11:03:24.6079034",
"IsDeleted": false,
"Ticket": {
"$ref": "4"
},
"User": null
}
}
]
}
这是Ajax:
<script type="text/javascript">
$(document).ready(function () {
loadData();
});
function loadData() {
$.ajax({
url: "/Ticket/GetMyTickets",
type: "Get",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (ListData) {
var str = "";
for (var i = 0; i < ListData.length; i++) {
$.each(ListData[i], function (index, items) {
str += "<tr>";
str += "<td>" + ListData[i].Status + "</td>";
str += "<td>" + ListData[i].priority + "</td>";
str += "<td>" + ListData[i].TrackingCode + "</td>";
str += "<td>" + ListData[i].CreateDate + "</td>";
str += "<td>" + ListData[i].IsPrivate + "</td>";
str += "<td>" + ListData[i].To + "</td>";
str += "<td><a onclick=Edit(this) data-toggle='modal' data-
target='#myModal'>نمایش پاسخ ها</a></td>";
str += "</tr>";
},
BodyData.innerHTML = str);
$(".TblData tr").fadeIn(1000);
};
}
});
}
我搜索了很多,但没有找到解决问题的方法。
更新 这是 console.log(ListData):
的输出 {
"$id": "1",
"$values": [
{
"$id": "2",
"TicketId": 33,
"Author": "5aff2283-5e71-4b10-a809-7c0235ccc18d",
"To": "f956d006-72b7-4a4c-b5cf-9354d6e6f193",
"Status": 2,
"priority": 0,
"TrackingCode": "f316a0d4bf9c4014a8acce1c152a56de",
"CreateDate": "2021-04-04T10:15:09.7256989",
"IsPrivate": false,
"IsDeleted": false,
"User": {
"$id": "3",
"FullName": "\u0645\u062F\u06CC\u0631 \u0633\u0627\u06CC\u062A",
"Avatar": "DefualtAvatar.jpg",
"IsDelete": false,
"CreateDate": "2021-03-16T13:05:20.6549686",
"EditDate": null,
"Id": "5aff2283-5e71-4b10-a809-7c0235ccc18d",
"UserName": "09876543210",
"NormalizedUserName": "09876543210",
"Email": "nikitmb2@gmail.com",
"NormalizedEmail": null,
"EmailConfirmed": false,
"PasswordHash":
"AQAAAAEAACcQAAAAEFbvXk/J1tXDz/
gAkIwWVjGWwSCeVhRgpPM0PVaRt1NJ1xlNr8HhxtMNWgd2u40BQw==",
"SecurityStamp": "IELKDSXBF5RE3MFHN7CNVOIGWWMK4QAV",
"ConcurrencyStamp": "517cf6f0-2f41-44a6-9a99-9512e0ffc471",
"PhoneNumber": "09876543210",
"PhoneNumberConfirmed": false,
"TwoFactorEnabled": false,
"LockoutEnd": null,
"LockoutEnabled": true,
"AccessFailedCount": 0
},
"ApplicationRole": {
"$id": "4",
"Title": "\u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06CC\u0633",
"Description": null,
"IsDelete": false,
"CreateDate": "2021-03-17T12:20:46.6002855",
"EditDate": null,
"ParentId": null,
"Roles": null,
"Id": "f956d006-72b7-4a4c-b5cf-9354d6e6f193",
"Name": "programmer",
"NormalizedName": "PROGRAMMER",
"ConcurrencyStamp": "a76600ef-8e82-4479-915d-41ad750cad5d"
},
"Answer": {
"$id": "5",
"AnswerId": 6,
"TicketId": 33,
"UserId": "5aff2283-5e71-4b10-a809-7c0235ccc18d",
"AnswerText": "\u003Cp\u003Ebbbbbb\u003C/p\u003E\r\n",
"File": null,
"DateTime": "2021-04-05T11:03:24.6079034",
"IsDeleted": false,
"Ticket": {
"$ref": "2"
},
"User": {
"$ref": "3"
}
}
}
]
}
根据您的 json 结构,您只需要一个循环来遍历 json 数组。因此,只需在 $.each
中使用 ListData["$values"]
,然后使用键名获取相应的值。
演示代码 :
//just for demo
var ListData = {
"$id": "1",
"$values": [{
"$id": "2",
"TicketId": 32,
"Author": "5aff2283-5e71-4b10-a809-7c0235ccc18d",
"To": "f956d006-72b7-4a4c-b5cf-9354d6e6f193",
"Status": 1,
"priority": 2,
"TrackingCode": "1bbdd10553634f2fbab1769cbf0b1b44",
"CreateDate": "2021-04-04T10:10:35.5043873",
"IsPrivate": true,
"IsDeleted": false,
"User": null,
"ApplicationRole": {
"$id": "3",
"Title": "\u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06CC\u0633",
"Description": null,
"IsDelete": false,
"CreateDate": "2021-03-17T12:20:46.6002855",
"EditDate": null,
"ParentId": null,
"Roles": null,
"Id": "f956d006-72b7-4a4c-b5cf-9354d6e6f193",
"Name": "programmer",
"NormalizedName": "PROGRAMMER",
"ConcurrencyStamp": "a76600ef-8e82-4479-915d-41ad750cad5d"
},
"Answer": null
},
{
"$id": "4",
"TicketId": 33,
"Author": "5aff2283-5e71-4b10-a809-7c0235ccc18d",
"To": "f956d006-72b7-4a4c-b5cf-9354d6e6f193",
"Status": 2,
"priority": 0,
"TrackingCode": "f316a0d4bf9c4014a8acce1c152a56de",
"CreateDate": "2021-04-04T10:15:09.7256989",
"IsPrivate": false,
"IsDeleted": false,
"User": null,
"ApplicationRole": {
"$ref": "3"
},
"Answer": {
"$id": "5",
"AnswerId": 6,
"TicketId": 33,
"UserId": "5aff2283-5e71-4b10-a809-7c0235ccc18d",
"AnswerText": "\u003Cp\u003Ebbbbbb\u003C/p\u003E\r\n",
"File": null,
"DateTime": "2021-04-05T11:03:24.6079034",
"IsDeleted": false,
"Ticket": {
"$ref": "4"
},
"User": null
}
}
]
}
$(document).ready(function() {
loadData();
});
function loadData() {
/* $.ajax({
url: "/Ticket/GetMyTickets",
type: "Get",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function(ListData) {*/
var str = "";
//get values array
$.each(ListData["$values"], function(index, items) {
//use items.nameofkey
str += "<tr>";
str += "<td>" + items.Status + "</td>";
str += "<td>" + items.priority + "</td>";
str += "<td>" + items.TrackingCode + "</td>";
str += "<td>" + items.CreateDate + "</td>";
str += "<td>" + items.IsPrivate + "</td>";
str += "<td>" + items.To + "</td>";
str += "<td><a href='#' onclick='Edit(this)' data-toggle='modal' data-target='#myModal'> نمایش پاسخ ها </a></td> ";
str += "</tr>";
});
$(".TblData").html(str)
$(".TblData").fadeIn(1000);
/* };
}
});*/
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<table border="1">
<tbody class="TblData"></tbody>
</table>