Итак, я использую запрос AJAX для загрузки данных из базы данных в DIV. В то же время я использую те же данные внутри DIV в другом скрипте (Poptrox), который занимается дизайном.
Без запроса AJAX poptrox работает, но если я использую его вместе с poptrox, он больше не занимается проектированием.
Есть ли способ перезагрузить скрипт poptrox после запроса ajax?
ВНИМАНИЕ: AJAX-код и Poptrox-код находятся внутри "main.js"!
Заранее спасибо!
php:
<script src = "assets/js/jquery.min.js"></script>
<section class = "wrapper">
<form action = "kochbuch.html" method = "get" id = "searchfilter">
<input type = "text" class = "searchBox" name = "searchBox" id = "searchBox" placeholder = "Search..">
<button type = "submit" id = "searchBtn"><i class = "fas fa-search"></i></button>
</form>
</section>
<section class = "wrapper">
<div id = "gerichte"></div>
</section>
<script src = "assets/js/main.js"></script>
js-аякс:
var queryString = window.location.search;
var urlParams = new URLSearchParams(queryString);
if (urlParams.has('searchBox')){
var searchBox = urlParams.get('searchBox');
$.ajax({
type: "POST",
url: "kochbuch/fetchdata.php",
data: {
"search_post_btn": 1,
"searchBox": searchBox,
},
dataType: "json",
success: function (response) {
$("#gerichte").html(response);
}
});
};
js-поптрокс:
// Gerichte.
var $gerichte = $('#gerichte');
// Thumbs.
$gerichte.children('.thumb').each(function() {
var $this = $(this),
$image = $this.find('.image'), $image_img = $image.children('img'),
x;
// No image? Bail.
if ($image.length == 0)
return;
// Image.
// This sets the background of the "image" <span> to the image pointed to by its child
// <img> (which is then hidden). Gives us way more flexibility.
// Set background.
$image.css('background-image', 'url(' + $image_img.attr('src') + ')');
// Set background position.
if (x = $image_img.data('position'))
$image.css('background-position', x);
// Hide original img.
$image_img.hide();
});
// Poptrox.
$gerichte.poptrox({
baseZIndex: 20000,
caption: function($a) {
var s = '';
$a.nextAll().each(function() {
s += this.outerHTML;
});
return s;
},
fadeSpeed: 300,
onPopupClose: function() { $body.removeClass('modal-active'); },
onPopupOpen: function() { $body.addClass('modal-active'); },
overlayOpacity: 0,
popupCloserText: '',
popupHeight: 150,
popupLoaderText: '',
popupSpeed: 300,
popupWidth: 150,
selector: '.thumb > a.image',
usePopupCaption: true,
usePopupCloser: true,
usePopupDefaultStyling: false,
usePopupForceClose: true,
usePopupLoader: true,
usePopupNav: true,
windowMargin: 50
});
// Hack: Set margins to 0 when 'xsmall' activates.
breakpoints.on('<=xsmall', function() {
$main[0]._poptrox.windowMargin = 0;
});
breakpoints.on('>xsmall', function() {
$main[0]._poptrox.windowMargin = 50;
});



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


хорошо, я нашел одно возможное решение, но знаю, что предварительно загруженные данные отформатированы:
весь код poptrox должен быть обернут этой функцией:
$(document).ajaxStop(function () {
// function after ajax
});
Если вы знаете лучшее решение, не стесняйтесь отправлять :)
Обновлено:
хорошо, мое решение было следующим:
if (urlParams.has('searchBox')){
var searchBox = urlParams.get('searchBox');
} else {
var searchBox = '';
}
$.ajax({ .....