- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这是我的问题。
我使用 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
属性 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/
我正在尝试通过 node.js 中的 puppeteer 抓取数据 目前,我正在寻找一个脚本,用于抓取 well.ca 某个部分中的所有数据 现在,这是我试图通过 node.js 实现的方法/逻辑 1
href=""、href="#" 和 href="javascript:void(0)" 之间有什么区别? 它们有哪些不同的用途,什么时候一个比另一个更好? 最佳答案 href=""将重新加载当前页面
这是html代码: Delivery Schedule Route Abstract Report 我有 href 值。使用 href 值,我应该找到 anchor 标记并使用 jQuery
我不确定是不是因为我使用的是 Wordpress 但 this.href 没有返回包含它们的项目的 href(例如在“联系人”上它返回 http://www.domain.net/undefined反
这个问题在这里已经有了答案: Is there a "previous sibling" selector? (33 个答案) 关闭 8 年前。
这个问题在这里已经有了答案: Are you allowed to nest a link inside of a link? (9 个回答) 关闭 6 年前。 我有一个可点击的面板,其中有一个工具
我的 css 如下所示 ul.sometclass li a { display:inline-block; } 我的 html 看起来像 outer test
我没看明白这段代码是什么意思? a[href*=#]:not([href=#]) 谢谢! 最佳答案 简单地: a[href*=#] 获取 href 中包含 # 的所有 anchor (a)。 但是有:
document.getElementById("IDOFELEMENT"); 将其转换为链接的正确方法是什么? 我可以写吗 document.getElementById("IDOFELEME
所以我在我的 Next JS 应用程序中遇到了这个奇怪的问题,我导入了谷歌字体,如下所示 在我的浏览器中显示的不是 href,而是 data-href="...",所以问题是谷歌无法将此识别为链接
我想获取所选选项的 href 值,以便我现在可以转到使用按钮选择的链接。 这是我的代码
我正在尝试获取我的一个链接的 href 并将其克隆/复制到另一个链接的 href 这是我正在尝试的 var link = $('.topbook'); var link2 =
我基本上是试图从一个链接获取href,然后将其填充到另一个链接中: HTML: Link to thing Link to duplicate 脚本: $('.main-link').attr('hr
我使用的 CSS 工具提示必须包含在“a href”中才能工作。 iPad [add_to_cart_anchor item="ipad"]purchase the iPad[/add_to_c
我有一个以前是纯文本的电子邮件正文,但现在我把它变成了 HTML。电子邮件是使用多种方法生成的,但没有一种方法易于转换。 我有的是: Some content emailaddress@somethi
我正在尝试从网页中抓取数据,然后通过提取下一页的 href 来转到下一页。 但是,在这种情况下,包含下一页的 href 的标签是 href='#next'。使用 Chrome 检查此元素后,当我将鼠标
在我的 html 页面中,我看到一个链接,其“查看源代码”代码如下: 当我将鼠标悬停在链接上并单击它时,我看到了一个有效链接。但我无法找到生成此 URL 的位置和方式。我发现类 a.view 是在其
看完这篇文章net.tutsplus.com/tutorials/javascript-ajax/14-helpful-jquery-tricks-notes-and-best-practices/我
我想用 SvelteKit 构建一个 Web 应用程序,其中一页列出所有项目(带有潜在的搜索查询参数),然后每个单独的项目一页。如果我必须使用后端生成的所有内容以老式方式构建它,我的路径将是 /ite
此 js 搜索包含 page=fleet 的 href其中: var links = document.querySelectorAll('a[href*="page=fleet"]'); var h
我是一名优秀的程序员,十分优秀!