Конечно, кто-то должен иметь представление о том, как заставить это работать ...
Мой блог в настоящее время настроен так, что у меня есть настраиваемая страница, на которой отображаются только сообщения данной категории. В каждом сообщении есть кнопка переключения. Когда кнопка переключателя нажата, сообщение скрывается (ВСЕ div скрыто с заголовком и всем содержимым сообщения). Это работает как хотелось бы.
Страница также настроена на отображение 10 сообщений на странице. Если у меня есть 11 сообщений, 11-е будет перенесено на страницу 2. Это работает как нужно.
Проблема в том, что при переключении поста (скажем, пост 3) у меня остается всего 9 постов на этой странице, а пост 11 остается на странице 2. То, что я хочу, - это когда пост 3 переключается, сообщение 11 должно переноситься на страницу 1, причем страница 2 практически исчезает (поскольку там нет сообщений для отображения).
Для иллюстрации:
Страница 1 отображает сообщения 1,2,3,4,5,6,7,8,9,10
На странице 2 отображаются сообщения 11 ... и т. Д.
Если сообщение 3 переключено:
Страница 1 отображает сообщения 1,2,4,5,6,7,8,9,10,11
Страница 2 исчезает (если нет поста 12,13 и т. Д.)
Кто-нибудь знает, как это реализовать?
page.php:
<?php
$paged = (get_query_var('paged')) ? get_query_var('paged') : 1;
$args = array(
'category_name' => 'post',
'paged' => $paged,
'posts_per_page' => 10
);
query_posts($args);
while (have_posts()) : the_post();
?>
..........the posts are displayed.............
<?php endwhile; ?>
<script type="text/javascript">
var pager = new Imtech.Pager();
$(document).ready(function() {
pager.paragraphsPerPage = 5; // set amount elements per page
pager.pagingContainer = $('#paginate'); // set of main container
pager.paragraphs = $('div.z', pager.pagingContainer); // set of required containers
pager.showPage(1);
});
</script>
toggle.js
$(document).on("click", ".toggle", function(){
postID = $(this).attr('id').replace('toggle_', '');
// Declare variables
value = '0';
myajax();
return false;
});
function myajax(){
// Send values to database
$.ajax({
url: 'check.php',
//check.php receives the values sent to it and stores them in the database
type: 'POST',
data: 'postID=' + postID + '&value=' + value,
success: function(result) {
$('#post_' + postID).toggle();
}
});
}
pagination.js
var Imtech = {};
Imtech.Pager = function() {
this.paragraphsPerPage = 3;
this.currentPage = 1;
this.pagingControlsContainer = '#pagingControls';
this.pagingContainerPath = '#contained';
this.numPages = function() {
var numPages = 0;
if (this.paragraphs != null && this.paragraphsPerPage != null) {
numPages = Math.ceil(this.paragraphs.length / this.paragraphsPerPage);
}
return numPages;
};
this.showPage = function(page) {
this.currentPage = page;
var html = '';
this.paragraphs.slice((page-1) * this.paragraphsPerPage,
((page-1)*this.paragraphsPerPage) + this.paragraphsPerPage).each(function() {
html += '<div>' + $(this).html() + '</div>';
});
$(this.pagingContainerPath).html(html);
renderControls(this.pagingControlsContainer, this.currentPage, this.numPages());
}
var renderControls = function(container, currentPage, numPages) {
var pagingControls = 'Page: <ul>';
for (var i = 1; i <= numPages; i++) {
if (i != currentPage) {
pagingControls += '<li><a href="#" onclick="pager.showPage(' + i + '); return false;">' + i + '</a></li>';
} else {
pagingControls += '<li>' + i + '</li>';
}
}
pagingControls += '</ul>';
$(container).html(pagingControls);
}
}
Итак, есть идеи?