php ajax复选框是否选中的值,jquery-ajax - php+ajax分页时,checkbox复选框选中的问题...

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

这个该如何实现呢?..分页这个我没问题,但是这个复选框一点下一页,就会给刷新掉

回复内容:

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

这个该如何实现呢?..分页这个我没问题,但是这个复选框一点下一页,就会给刷新掉

两种方案

方案1

- - -

1. 每一个页面一个单独的容器(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);

});

选中后用一个数组变量a[]来保存选中的id;

分页时上一页数据的那部分html是删掉的还是隐藏的?删掉了肯定就肯定也没有了呀。

这样的情况就像购物车一样对吧?每一页选中的商品都扔进购物车,再批量处理。

我用CodeIgniter的时候用里面的购物车类处理过这种情况。原理就是用session存储选中的ID,每个ID会生成一个唯一的rowid,渲染页面的时候根据生成的rowid判断当前项是否被选中。

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值