这是我的问题。
我使用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'},];
我得到带有响应文本的弹出窗口。
演示版
我做错了什么?
“ 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
属性以字符串形式获取响应数据,因此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文档中的API方法):
var img = dataXarrayObj;
$.fancybox(img, opts);
或简单地
$.fancybox(dataXarrayObj, opts);
请注意,您不需要将 数组 括在[]
方括号中
问题内容: 我的问题是我有一个大型画廊,不应在第一页加载时完全加载。因此,我加载了50张图像中的10张,并向其中添加了fancybox。当用户单击下一步按钮时,第11张图像应通过Ajax加载并附加到图库容器中。 问题是fancybox停止在第10张图片,因为它不知道动态加载的图片。 如何将动态加载的图像添加到fancybox2? 目前我有这个: 获取下一张图片:) 之后,我调用loadFancyb
由于公司需求原因需要从试剂中获取每个圆圈(总共6个)里的RGB区间值 之前是没有做过此类 后来问了一下ChatGPT 以及通过查阅资料写了代码 去获取RGB 区间值 结果就是陷入死循环 请教哪位大神做过?
问题内容: 我经常去一个网站查找东西。我对自己心想:“继续。我可以编程。当我可以编写一个可以为我做的软件时,为什么要手动进入该站点?”。 所以我开始了。我正在使用C#,所以我找到了WebClient和Uri。 我已经设法获取了该站点的源代码,但是问题出在加载源代码之后,我要查找的特定数据是通过AJAX生成的。 那就是我的问题。如果需要先通过AJAX调用来请求,该如何获取该代码? 问题答案: 通用方
看网上的方法大多是这样的 然后可以在img.load () {} 获取到上传图片的宽高 但是呢更到线上后,上传图片就被拦截了,blob不太行,所以想问一下有不通过blob的方式获取到上传图片的宽高吗,报错信息大致是 有啥解决办法呢,只想获取图片的宽高~~~
问题内容: 我想获取单选按钮值并将其通过AJAX发送到PHP。 我的AJAX正在运行,但当前正在每行中插入一个,因此它不会从单选按钮中获取值。任何帮助,将不胜感激。 问题答案: 首先,您有很多重复的属性,这是不正确的。请改用类,然后使用选择器来获取所选无线电的特定实例。 试试这个: 以此类推,作为您的其他输入。
问题内容: 我想将页面上的一些数据发送到servlet 所以我写了下面的jQuery来做到这一点 我使用所有数据构建一个json字符串,并将其直接发送到servlet 但是我不知道如何从servlet中的ajax获取全部数据 如果查看来自chrome的请求标头的Form Data段 您会看到整个json字符串是关键。 问题答案: 看这里, 您的归属是错误的。它不应该是字符串,而是真实的JSON对象