dwz 分页 bug (选回 combox 第一个值时不执行 onchange)

先看一下官方的测试:

官方的演示有两个 bug 一个是combox数字一直不变,二是当选回第一个值时不执行 onchange 事件。

经过firebug调试,这是一个bug,传到后台的参数没有得到及时替换,具体bug修复如下:
修改dwz.ajax.js中代码:
/**
 * 处理navTab中的分页和排序
 * targetType: navTab 或 dialog
 * rel: 可选 用于局部刷新div id号
 * data: pagerForm参数 {pageNum:"n", numPerPage:"n", orderField:"xxx", orderDirection:""}
 * callback: 加载完成回调函数
 */
// 存在一个bug,没有替换options中的numPerPage大小
function dwzPageBreak(options){
    var op = $.extend({ targetType:"navTab", rel:"", data:{pageNum:"", numPerPage:"", orderField:"", orderDirection:""}, callback:null}, options);
    var $parent = op.targetType == "dialog" ? $.pdialog.getCurrent() : navTab.getCurrentPanel();
 
    if (op.rel) {
        var $box = $parent.find("#" + op.rel);
        var form = _getPagerForm($box, op.data);
        // 替换form中的numPerPage值
        var params = $(form).serializeArray();
        if (op.numPerPage) {
            params[1].value = op.numPerPage;
        }
         
        if (form) {
            $box.ajaxUrl({
                type:"POST", url:$(form).attr("action"), data: params, callback:function(){
                    $box.find("[layoutH]").layoutH();
                }
            });
        }
    } else {
        var form = _getPagerForm($parent, op.data);
        var params = $(form).serializeArray();
        // 替换form中的numPerPage值
        if (op.numPerPage) {
            params[1].value = op.numPerPage;
        }
         
        if (op.targetType == "dialog") {
            if (form) $.pdialog.reload($(form).attr("action"), {data: params, callback: op.callback});
        } else {
            if (form) navTab.reload($(form).attr("action"), {data: params, callback: op.callback});
        }
    }
}

完美解决了分页问题及选回 combox 第一个值不执行 onchange 事件。

记录一下...

 

转载于:https://www.cnblogs.com/interdrp/p/4047935.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值