Wordpress JQuery Как сбросить нумерацию страниц при переключении сообщения - PullRequest
0 голосов
/ 17 ноября 2011

Конечно, кто-то должен иметь представление о том, как заставить это работать ...

Мой блог в настоящее время настроен так, что у меня есть настраиваемая страница, на которой отображаются только сообщения данной категории. В каждом сообщении есть кнопка переключения. Когда кнопка переключателя нажата, сообщение скрывается (ВСЕ 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);
}
}

Итак, есть идеи?

1 Ответ

0 голосов
/ 17 ноября 2011

Мой ответ будет для перезагрузки текущей страницы с сообщениями через ajax.

  • нет проблем с генерацией пагинации через javascript и php
  • у вас такое же поведение для начальной загрузкии последующие загрузки (когда пользователь скрывает сообщение)
  • Вы можете сделать работу с нумерацией страниц с помощью jquery довольно просто
...