带有 Ajax 的 jQuery FancyBox

Posted

技术标签:

【中文标题】带有 Ajax 的 jQuery FancyBox【英文标题】:jQuery FancyBox with Ajax 【发布时间】:2015-09-29 20:15:00 【问题描述】:

我在 *** 上查看了许多网站和许多页面,但它们都没有解决我的问题。简单地说,我有一个hyperlink,我想通过Ajax 调用从数据库中检索图像,然后将其显示在FancyBox 弹出窗口中。我还尝试了javascriptController 操作方法的许多不同组合,但没有管理,因此正确显示下载的文件。您能否看看我的代码并给出一个包含ViewController 中所有必要方法的工作示例?另一方面,最好为其他文件类型(即 excel、pdf)打开一个对话框,同时为图像文件打开 FancyBox

查看:

<a onclick="downloadFile(@Model.ID);">@Model.FileName</a>


function downloadFile(id)      
    $.ajax(
        url: "/Issue/RenderImage?ID=" + id,
        async: true,
        type: "POST",
        dataType: "json",
        contentType: "application/json; charset=utf-8",
        success: function (response) 
            $('#fancybox-inner').html('<img   src="data:image/png;base64,' + response + '" />');
               
    );

Controller:Controller中的方法没有问题,可以正常返回图片。

[HttpPost]
public virtual JsonResult RenderImage(int id)

    string str = System.Convert.ToBase64String(repository.FileAttachments.FirstOrDefault(p => p.ID == id).FileData, 0, repository.FileAttachments.FirstOrDefault(p => p.ID == id).FileData.Length);
    return Json(new  Image = str, JsonRequestBehavior.AllowGet );

【问题讨论】:

【参考方案1】:

最好试试

success: function (response) 
    $.fancybox(
        content: '<img   src="data:image/png;base64,' + response + '" />',
        type: "html"
    );
  

我想知道为什么您尝试在fancybox 容器中加载内容,而您却没有在已经打开它的地方显示任何代码。无论如何,最好用新内容(来自 ajax 响应)启动一个新的 fancybox

当然,如果 ajax 调用为您的 &lt;img&gt; 标记返回正确响应,这将起作用,但我无法确定。

【讨论】:

【参考方案2】:

这应该可行。看起来图像存储为 JSON。如果是这样,我认为您应该在将其发送到浏览器之前将其转换回 Base64。见http://mobile.cs.fsu.edu/converting-images-to-json-objects/

function downloadFile(id) 
    $('#fancybox-inner').html('<img   src="/Issue/RenderImage?ID='+id+'" />');

【讨论】:

感谢回复,图片存储为byte[]。我也看看你提到的页面,但我真的很困惑控制器中的方法和 Javascript 方法。另一方面,您的示例不使用 Ajax,是否可以在不回发的情况下检索图像?如果我们不使用Ajax,我认为这似乎是不可能的。那么,您能否检查一下并澄清我应该遵循的内容? :( 我不确定您使用的是哪种服务器端语言,但如果您使用它返回正确的标题和常规 jpeg 或 png 格式的图像,我的方法将起作用。如果您不依赖浏览器转换图像,您应该可以获得更一致的跨浏览器结果

以上是关于带有 Ajax 的 jQuery FancyBox的主要内容,如果未能解决你的问题,请参考以下文章

ajax成功后点击事件的jQuery Fancybox显示没有图像

使用带有fancybox的jQuery流沙的问题

Ajax提交后如何关闭fancybox?

图片预览插件 fancyBox

在另一个fancybox ajax 上打开fancybox

jquery live & livequery