尝试构建一个mvc项目,该项目会将数据库中上传的图像加载到轮播中。我的问题是,图像将创建一个byte []列表并作为JsonResult从控制器发送到视图。问题是我不知道如何访问视图中JS代码中从控制器返回的每个元素。
这是我的控制器:
public JsonResult GetImages(string date, string sessionNumber)
{
int selectedSessionNumber = Convert.ToInt32(sessionNumber);
Guid getClassInfoId = (Guid)Session["infoId"];
var getSessionId= (from c in db.Session
where c.ClassInfoID == getClassInfoId && c.SessionNumber == selectedSessionNumber
select c.ID).ToList();
List<byte[]> getPics =new List<byte[]>();
foreach (var item in getSessionId)
{
getPics.Add((from c in db.ClassPicture where c.SessionID == item select c.PicFile).First());
}
List<string> imagesBase64 = new List<string>();
foreach (var pics in getPics)
{
var base64 = Convert.ToBase64String(pics);
imagesBase64.Add(base64);
}
return Json(imagesBase64, JsonRequestBehavior.AllowGet);
这是我的js代码:
function ShowImage() {
$.ajax({
url: '@Url.Action("GetImages", "Main")',
type: 'POST',
traditional: true,
data: { 'date': selectedDate, 'sessionNumber': selectedSession },
success: function (myData) {
var imgSrc = "data:image/jpeg;base64," + myData;
$('<div class="item"><img src=' +
imgSrc +
'><div class="carousel-caption"></div></div>').appendTo('.carousel-inner');
$('<li data-target="#carousel-example-generic" data-slide-to= 0></li>')
.appendTo('.carousel-indicators');
// }
//}
$('.item').first().addClass('active');
$('.carousel-indicators > li').first().addClass('active');
$('#carousel-example-generic').carousel(3);
// $('#carousel-example-generic').carousel();
}
});
};
最佳答案
将jQuery ajax dataType
指定为JSON(您希望从服务器返回的数据类型)。
使用myData
遍历$.each(myData, function(idx, imageBase64) { ... })
。
关于javascript - 从JsonResult获取值,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/46655407/