gpt4 book ai didi

jquery - FancyBox 通过 AJAX 获取图像的 href

转载 作者:行者123 更新时间:2023-12-01 04:21:47 24 4
gpt4 key购买 nike

这是我的问题。

我使用 FancyBox 来显示图像,这些图像通过 AJAX 获取。加载页面时,页面上不存在图像,只有带有画廊名称的属性的链接。

因此,当我单击这些链接之一时,处理了此代码:

    $(".fancybox-manual-c").live('click',function() {
$.ajax({
type : 'POST',
data : {'gal' : $(this).attr('rel')},
url : 'http://polygon.goracio.com.ua/gallery/getfiles.php',
//dataType: 'json',
complete: function(data) {
var dataX = data.responseText;
console.log(data.responseText);
var img = [
{href:'/gallery/galleries/gallery1/wallpapers_by_ellin-30711.jpg'},
{href:'/gallery/galleries/gallery1/wallpapers_by_ellin-27082.jpg'},
{href:'/gallery/galleries/gallery1/wallpapers_by_ellin-30988.jpg'},
{href:'/gallery/galleries/gallery1/wallpapers_by_ellin-30858.jpg'},
{href:'/gallery/galleries/gallery1/wallpapers_by_ellin-23424.jpg'},];
var opts = {
prevEffect : 'none',
nextEffect : 'none',
helpers : {
thumbs : {
width: 75,
height: 50
}
}
};
$.fancybox(img, opts);
}
});
});

这个解决方案工作正常。但是当我使用

    var img = [dataX];

而不是

            var img = [
{href:'/gallery/galleries/gallery1/wallpapers_by_ellin-30711.jpg'},
{href:'/gallery/galleries/gallery1/wallpapers_by_ellin-27082.jpg'},
{href:'/gallery/galleries/gallery1/wallpapers_by_ellin-30988.jpg'},
{href:'/gallery/galleries/gallery1/wallpapers_by_ellin-30858.jpg'},
{href:'/gallery/galleries/gallery1/wallpapers_by_ellin-23424.jpg'},];

我收到带有响应文本的弹出窗口。

Demo

我做错了什么?

  • fancyBox - jQuery 插件
  • 版本:2.0.5(2012 年 2 月 21 日)
  • jQuery 1.7 - 最新

“getfile.php”的代码

function directoryToArray($directory, $recursive = true) {
$array_items = array();
if ($handle = opendir($directory)) {
while (false !== ($file = readdir($handle))) {
if ($file != "." && $file != "..") {
if (is_dir($directory. "/" . $file)) {
if($recursive) {
$array_items = array_merge($array_items, directoryToArray($directory. "/" . $file, $recursive));
}
$directory = str_replace('./galleries/', '', $directory);
$file = $directory . "/" . $file;
$array_items[]= preg_replace("/\/\//si", "/", $file);
} else {
$directory = str_replace('./galleries/', '', $directory);
$file = $directory . "/" . $file;
$array_items[] = preg_replace("/\/\//si", "/", $file);
}
}
}
closedir($handle);
}
return $array_items;
}
header("Content-type: text/plain;charset=utf-8");
$arrays = directoryToArray( "./galleries/".$_POST['gal']);
foreach($arrays as $array){
echo "{href:'/gallery/galleries/$array'}, \n";
}

更新

        $(".fancybox-manual-ajax").live('click',function() {
$.ajax({
type : 'POST',
data : {'gal' : $(this).attr('rel')},
url : 'http://polygon.goracio.com.ua/gallery/getfiles.php',
dataType: 'text',
complete: function(data) {
var dataX = data.responseText;
var dataXsplit = dataX.split(',');
var dataXarrayObj = new Array(), i;
for(i in dataXsplit){
if(dataXsplit[i].length){ //remove last empty element after .split()
dataXarrayObj[i] = $.parseJSON(dataXsplit[i]);
}
}
var opts = {
prevEffect : 'none',
nextEffect : 'none',
helpers : {
thumbs : {
width: 75,
height: 50
}
}
};
$.fancybox(dataXarrayObj, opts);
}
});
});

最佳答案

嗯,你没有做错任何事,但在这种情况下有很多因素需要考虑

首先,从你的ajax调用中你得到:

var dataX = data.responseText;

responseText 属性 gets the response data as a string ,因此 fancybox 显示这样的字符串而不是图像的数组

您需要做的解决方法是将此类字符串转换为JavaScript 对象,以便fancybox可以解析它。有不同的方法可以做到这一点。一种是使用 eval() 函数,但可能存在安全问题,因此不建议使用此方法。

由于您使用的是 jQuery,最安全的方法是使用 jQuery.parseJSON( json ) ,但是您必须确保您将转换格式正确的 JSON 字符串。

就您而言,您的“getfile.php”文件似乎正在呈现这种格式

{href:'/gallery/galleries/gallery1/wallpapers_by_ellin-30711.jpg'},....

但是格式良好的 JSON 字符串应该如下所示:

{"href":"/gallery/galleries/gallery1/wallpapers_by_ellin-30711.jpg"},...

注意强制的双引号

一旦您确定 data.responseText 返回一个字符串,例如:

data.responseText='{"href":"/gallery/galleries/gallery1/wallpapers_by_ellin-30711.jpg"},{"href":"/gallery/galleries/gallery1/wallpapers_by_ellin-27082.jpg"}, etc ....'
var dataX = data.responseText;

那么你可以1)。分割字符串,2)。将每个分离的元素转换为 JavaScript 对象 和 3)。将其放入对象的数组中,例如:

var dataXsplit = dataX.split(',');
var dataXarrayObj = new Array(), i;
for(i in dataXsplit){
dataXarrayObj[i] = jQuery.parseJSON(dataXsplit[i]);
}

之后,您可以使用正确的数组对象来触发 fancybox(检查 fancybox documentation 中的 API 方法),或者执行以下操作:

var img = dataXarrayObj;
$.fancybox(img, opts);

或者简单地

$.fancybox(dataXarrayObj, opts);

请注意,您不需要将数组括在[]方括号中

关于jquery - FancyBox 通过 AJAX 获取图像的 href,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9842741/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com