jQuery Lightbox 代码适用于 JSFiddle,但不适用于 Wordpress 帖子

标签 jquery wordpress gallery image-gallery photo-gallery

我有一段 jQuery 灯箱代码。当我将它插入到 JSFiddle 上时,它可以工作 - 但当我在我的 Wordpress 网站上实现它时,它就不行了。

这是 JSFiddle:http://jsfiddle.net/cVxCz/4/

这是我的 WordPress 测试帖子:http://test.dansas.no/

这是我的 jQuery 代码。实际上没有必要在这里发布,因为它可以工作并且可以在 JSFiddle 和 Wordpress 帖子上找到,但是在这里:

jQuery(document).ready(function($) {

// global variables for script
var current, size;

$('a').click(function(e) {

// prevent default click event
e.preventDefault();

// grab href from clicked element
var image_href = $(this).attr("href");  

// determine the index of clicked trigger
var slideNum = $('a').index(this);

// find out if #lightbox exists
if ($('#lightbox').length > 0) {        
  // #lightbox exists
  $('#lightbox').fadeIn(300);
  // #lightbox does not exist - create and insert (runs 1st time only)
} else {                                
  // create HTML markup for lightbox window
  var lightbox =
      '<div id="lightbox">' +
      '<p>Close X</p>' +
      '<div id="slider">' +
      '<div class="nav">' +
      '<a class="prev slide-nav">prev</a>' +
      '<a class="next slide-nav">next</a>' +
      '</div>' +
      '</div>' +
      '</div>';

  //insert lightbox HTML into page
  $('body').append(lightbox);

  // fill lightbox with a hrefs in .gallery
  $('.gallery').find('figure > a').each(function() {
    var $href = $(this).attr('href');
    $('#slider').append(
      '<img src="' + $href + '">'
    );
  });

}

// setting size based on number of objects in slideshow
size = $('#slider img').length;

// hide all slide, then show the selected slide
$('#slider img').hide();
$('#slider img:eq(' + slideNum + ')').show();

// set current to selected slide
current = slideNum;
});

//Click anywhere on the page to get rid of lightbox window
$('body').on('click', '#lightbox', function() { // using .on() instead of .live(). more modern, and fixes event bubbling issues
$('#lightbox').fadeOut(300);
});

// show/hide navigation when hovering over #slider
$('body').on(
{ mouseenter: function() {
  $('.nav').fadeIn(300);
}, mouseleave: function() {
  $('.nav').fadeOut(300);
}
},'#slider');

// navigation prev/next
$('body').on('click', '.slide-nav', function(e) {

// prevent default click event, and prevent event bubbling to prevent lightbox from closing
e.preventDefault();
e.stopPropagation();

var $this = $(this);
var dest;

// looking for .prev
if ($this.hasClass('prev')) {
  dest = current - 1;
  if (dest < 0) {
    dest = size - 1;
  }
} else {
  // in absence of .prev, assume .next
  dest = current + 1;
  if (dest > size - 1) {
    dest = 0;
  }
}

// fadeOut curent slide, FadeIn next/prev slide
$('#slider img:eq(' + current + ')').fadeOut(100);
$('#slider img:eq(' + dest + ')').fadeIn(100);

// update current slide
current = dest;
});

$(document.documentElement).keyup(function (event) {

var $this = $(this);
var dest;

if (event.keyCode == 37) {
      dest = current - 1;
  if (dest < 0) {
    dest = size - 1;
  }
} 

else if (event.keyCode == 39) {
  dest = current + 1;
  if (dest > size - 1) {
    dest = 0;
  }
}

else if (event.keyCode == 27) {
  $('#lightbox').fadeOut(300);
}

   // fadeOut curent slide, FadeIn next/prev slide
$('#slider img:eq(' + current + ')').hide();
$('#slider img:eq(' + dest + ')').show();

// update current slide
current = dest;

});

});

请帮帮我。我知道这只是一件小事,但我不太擅长这一点。

最佳答案

在代码顶部包含 jquery...它未定义

尝试firebug你很容易得到错误

ReferenceError: jQuery is not defined

jQuery(document).ready(function($) {

test.dansas.no (line 13)

关于jQuery Lightbox 代码适用于 JSFiddle,但不适用于 Wordpress 帖子,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20867973/

相关文章:

Android Gallery 小部件 "jitter"/"jumping"/表现怪异

javascript - 从数据表中删除一行

jquery - 删除标签并仅在条形图的工具提示中显示值

php - 如何使用 MySQL 搜索和替换修复 WordPress 中损坏的链接?

php - 如何删除影响 WordPress 样式的页眉和页脚

iphone - 没有用户登录的 flickr 公共(public)图片库适用于 iphone 应用程序

android - Android 2d Gallery 源代码中未初始化的变量

javascript - 为什么我不能使用 javascript 和 jquery 读取文本文件?

javascript - 为每个数组设置随机颜色

mysql - SQL 和 WPDB 的困难,特别是在 WHERE 子句中