4

我目前正在尝试以 BLOB 的形式查看存储在数据库中的图像,为此我创建了一个 FileContentResult 类型的控制器操作,如下所示:

public FileContentResult ImageFile(string imageId)
    {
        var client = new WcfTestClient();

        DataTable table = client.GetImageData(imageId);
        var image = ConvertToBytes(table);
        byte[] bytes;

        bytes = image[0].Values.ElementAt(0);

        return File(bytes, @"image/png");
    }

它从数据库中获取正确的图像数据,并且 ConvertToBytes() 也可以正常工作,但由于某种原因,在将图像返回到视图后,它会跳回顶部并再次运行。

我正在使用 Ajax 从我的视图中调用该方法,如下所示:

$.ajax({
    url: "/Home/ImageFile",
    type: "GET",
    data: { "imageId": imageId },
    success: function (data) {
        var image = document.createElement('img');
        image.src = "/Home/ImageFile?id=" + imageId;
        image.width = 100;
        image.height = 100;
        div.appendChild(image);
    }
});

有谁知道什么可能导致我的问题?

更新

好的,所以现在在被告知是 Ajax 搞砸了之后,我尝试向我的 Controller Action 发送一个参数,如下所示:

var images = JSON.parse(window.localStorage.getItem("JsonImages"));
var div = document.getElementById('imgOutput');

for (var i = 0; i < images.length; i++) {
    var imageId = images[i].pi_Id;
    var imgId = JSON.parse('{"imageId":' + imageId + '}');

    var img = document.createElement('img');
    img.src = "/Home/ImageFile?id=" + imgId;
    img.width = 100;
    img.height = 100;
    div.appendChild(img);
}

可悲的是,这不是很好。那么,有没有办法将参数发送到 ImageFile() 而不让它运行两次?我在这里错过了一些基本的东西吗?

更新 2

最后我让它工作了!这是它现在的样子:

var images = JSON.parse(window.localStorage.getItem("JsonImages"));
var div = document.getElementById('imgOutput');

var createImage = function (src) {
    var img = document.createElement('img');
    img.src = src;
    img.height = 100;
    img.width = 100;
    return img;
}

for (var i = 0; i < images.length; i++) {
    var imageId = images[i].pi_Id;
    var imageSrc = "/Home/ImageFile?imageId=" + imageId;
    div.appendChild(createImage(imageSrc));
}

我只需要将源的参数从 id 更改为 imageId (duh)。谢谢你的帮助!

4

1 回答 1

6

问题是您首先向控制器操作发出 AJAX 请求ImageFile,然后,当它成功返回结果时,您创建一个引用同一路由的 DOM 元素,因此浏览器发出另一个请求以尝试创建图像标签。

从外观上看,您根本不需要 AJAX 调用。如果您只是创建带有动作路径的图像标签作为src,它应该可以工作。将您的回调从 AJAX 请求中拉success出来,然后单独使用它。

或者,如果你没有做任何特别动态的事情,你可以直接在你的图像src标签中使用路由,而根本不使用 Javascript。例如,如果您正在使用 Razor:

<image src="@(String.Format("/Home/ImageFile?id={0}", Model.MyImage))"
    height="100" width="100" />

如果它需要是动态的和基于 Javascript 的,你可以放弃 AJAX,因为你不需要它:

function createImage(src, width, height) {
    var img = document.createElement('img');
    img.src = src;
    img.height = height;
    img.width = width;
    return img;
}

var someId = /* Whatever your ID is */;
var imgSrc = "/Home/ImageFile?id=" + someId;
div.appendChild(createImage(imgSrc, 100, 100));
于 2013-05-03T07:08:29.030 回答