0

我从 Firefox 收到此错误:

TypeError: $(...).lightGallery(...).destroy is not a function

我正在使用以下插件播放视频并显示图片库 https://github.com/sachinchoolur/lightGallery

我想重新初始化 lightGallery,因为我正在使用 ajax 在容器中动态添加元素。它在以前版本的 lightGallery 上运行良好,但不适用于当前版本。

我正在使用以下代码。

// destroy previous gallery
$("#lightGallery2").lightGallery({
  selector : '.image_gallery',
  videojs: true,
  download: false
}).destroy();

// re-initialize
$("#lightGallery2").lightGallery({
  selector: '.image_gallery',
  videojs: true,
  download: false
});

请建议。

谢谢

4

5 回答 5

8

以下代码适用于我:

$lg.on('onBeforeClose.lg',function(event, index, fromTouch, fromThumb){
    try{$lg.data('lightGallery').destroy(true);}catch(ex){};
});
于 2016-06-20T18:47:24.070 回答
1

对于销毁数据,您应该将 data 属性添加到您的图库,然后将其销毁,例如,如果您将图库应用于所有链接:

var myGallery = 'body',
    lightgallery = function() {
         $( myGallery ).attr('data-lightGallery', '1');
         $( myGallery ).lightGallery({selector: 'a[href$=".jpg"], a[href$=".jpeg"], a[href$=".png"], a[href$=".gif"]'});
    };

然后:

$( myGallery ).data('lightGallery').destroy(true);
lightgallery();
于 2016-03-29T18:41:06.460 回答
0

如果它像大多数插件/小部件一样编写,你应该像这样调用destroy方法。

$("#lightGallery2").lightGallery("destroy");
于 2015-09-18T11:19:36.030 回答
0

您必须使用以下方法来销毁lightgallery 1.2.x版本。

var $lg = $('#lightGallery2');

$lg.lightGallery({
  selector : '.image_gallery',
  videojs: true,
  download: false
});

$lg.data('lightGallery').destroy(true);

这是文档

于 2015-09-19T02:28:08.897 回答
0

我只是创建了一个全局变量。它允许我执行所需的功能。

var PLUGIN; // global variable
...
if(PLUGIN) PLUGIN.data('lightGallery').destroy(true); // destroy 
PLUGIN = $("#lightGallery2").lightGallery();
于 2021-11-22T15:17:05.783 回答