您好,匿名用户
随意问技术百科期待您的加入

php+ajax分页时,checkbox复选框选中的问题

0 投票

目的:所有的数据实现分页显示,不是查询所有的数据,而是每次取固定的条数。而且在每页选中的数据ID都可以保存,一起提交选中的数据,做相应的操作。比如第一页选中2条,第二页选中3条,提交时是5条,如果返回第一页,这也显示选中的数据,回到第二页,也会显示选中的数据,以此类推,取消选中,翻页几次,无任何问题;总之,无论选中还是取消,翻页都没有bug
这个该如何实现呢?..分页这个我没问题,但是这个复选框一点下一页,就会给刷新掉

用户头像 提问 2013年 11月10日 @ Morgana 上等兵 (251 威望)
分享到:

1个回答

0 投票

两种方案

方案1
- - -
1. 每一个页面一个单独的容器(div)。

<div class="content">
    <div class="page page-1">
        ...
    </div>
</div>

2. 加载新页面时,首先检查该页面是否已经加载过了,例如加载页面4

// 代码仅为示意
if($('.page-4', '.content').length > 0) {
    $('.page', '.content').hide();
    $('.page-4', '.content').show();
} else {
    page4 = render_page(load_page(4)); //得到page4的结构
    $('.page', '.content').hide();
    $('.content').append(page4);
}

这样在切换页面的时候就可以保存页面信息了。

方案2
- - -
创建一个对象来存放页面数据,并且让它支持自定义事件。当PAGE内容发生改变时,重新按照PAGE进行渲染。这实际上是一个MVC的方案。

下面的代码随手写的,只是为了示意。请勿直接使用。

// 可以用EventEmitter等等事件库来支持,我这里为了简单就用jQuery啦
var PAGE = $({
    current: -1,
    data: {}
});
PAGE.extend({
    fetch: function() {
        $.get('url', function(data) {
            this.data[current_page] = data
            this.trigger('value_change');
        })
    },
    show: function(page) {
        PAGE.current = page;
        if(this.data[page]) {
            this.trigger('value_change');
        } else {

            this.fetch(page);
        }
    },
});
PAGE.bind('value_change', function() {
    render_page();
});

var render_page = function() {
        if(PAGE[PAGE.current]) {
            //按照PAGE[PAGE.current]的内容渲染 div#page的内容
        } else {
            throw('error');
        }
    };


$('input[type="checkbox"]', '#page').change(function() {
    // 更新PAGE内容
    PAGE.data[current_page][item] = value

    PAGE.trigger(value_change);
});
用户头像 回复 2013年 11月10日 @ Diana 上等兵 (326 威望)
提一个问题:

相关问题

+1 投票
1 回复 66 阅读
用户头像 提问 2013年 1月26日 @ Kyrie 上等兵 (240 威望)
0 投票
1 回复 177 阅读
用户头像 提问 2012年 12月1日 @ Artemis 上等兵 (162 威望)
0 投票
1 回复 62 阅读
用户头像 提问 2013年 9月18日 @ Darius 上等兵 (331 威望)
0 投票
1 回复 33 阅读
0 投票
1 回复 31 阅读
用户头像 提问 2012年 12月1日 @ Trish 上等兵 (154 威望)

欢迎来到随意问技术百科, 这是一个面向专业开发者的IT问答网站,提供途径助开发者查找IT技术方案,解决程序bug和网站运维难题等。
温馨提示:本网站禁止用户发布与IT技术无关的、粗浅的、毫无意义的或者违法国家法规的等不合理内容,谢谢支持。

欢迎访问随意问技术百科,为了给您提供更好的服务,请及时反馈您的意见。
...