DWZ局部刷新实现

2023-11-23 16:58
文章标签 实现 刷新 局部 dwz

本文主要是介绍DWZ局部刷新实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题:我要刷新回收站页签的列表

当点击刷新的时候,我需要当前页面的数据进行刷新,而不是刷新整改页面


QQ截图20180823221136.png

分析:

使用DWZ自带框架的navTabPageBreak(args,rel)方法,需要传入两个参数。

    navTabPageBreak(args,rel)方法代码如下:

/**  

 * 处理navTab中的分页和排序  

 * @param args {pageNum:"n", numPerPage:"n", orderField:"xxx", orderDirection:""}  

 * @param rel: 可选 用于局部刷新div id号  

 */  

function navTabPageBreak(args, rel){  

        //实质上调用的 dwzPageBreak 方法,dwzPageBreak 是对navTab和dialog通用一个方法  

    dwzPageBreak({targetType:"navTab", rel:rel, data:args});  

}  

   

/**  

 * 处理navTab中的分页和排序  

 * targetType: navTab 或 dialog  

 * rel: 可选 用于局部刷新div id号  

 * data: pagerForm参数 {pageNum:"n", numPerPage:"n", orderField:"xxx", orderDirection:""}  

 * callback: 加载完成回调函数  

 */  

   

 //这个方法是重点  

 function dwzPageBreak(options){  

        //这里设置一些默认是属性  

    var op = $.extend({ targetType:"navTab", rel:"", data:{pageNum:"", numPerPage:"", orderField:"", orderDirection:""}, callback:null}, options);  

        //获取默认的父容器,一般就是当前的dialog和当的navTab  

        var $parent = op.targetType == "dialog" ? $.pdialog.getCurrent() : navTab.getCurrentPanel();  

        //这里是局部的刷新, 流程就是通过Ajax请求获取到新的html片段,替换掉 指定的id (op.rel)节点,然后从新格式化布局。  

    if (op.rel) {  

        var $box $parent.find("#" + op.rel);  

                //获取当前页面的查询form 下面会重点讲解  

        var form = _getPagerForm($box, op.data);  

        if (form) {  

                        //获取新的html片段,替换掉原始的。  

            $box.ajaxUrl({                                         //获取查询表单里参数,所以刷新页面时表表单数据是一并发过去的   

                type:"POST", url:$(form).attr("action"), data: $(form).serializeArray(), callback:function(){  

                                        //重新格式化布局  

                    $box.find("[layoutH]").layoutH();  

                }  

            });  

        }  

         //刷新整个 navTab、或者 dialog  

         else {  

             //获取当前页面的查询form 下面会重点讲解  

             var form = _getPagerForm($parent, op.data);  

               

            //获取查询表单里参数,所以刷新页面时表表单数据是一并发过去的   

            var params = $(form).serializeArray();  

            //通过各个reload方法可以刷新  

            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});  

            }  

         }  

}  

   

/**  

 *   

 * @param {Object} args {pageNum:"",numPerPage:"",orderField:"",orderDirection:""}  

 * @param String formId 分页表单选择器,非必填项默认值是 "pagerForm"  

 */  

   

//dwzPageBreak 方法调用这个方法   

function _getPagerForm($parent, args) {  

         //获取当前页面下查询Form节点  

         //#pagerForm Id 名字很重要 如果传递不了参数,可以检查一下 ID 名称         

        var form = $("#pagerForm"$parent).get(0);  

    if (form) {  

                //在这里会把你传递的参数附上。  

        if (args["pageNum"]) form[DWZ.pageInfo.pageNum].value = args["pageNum"];  

                //<select class="" onchange="navTabPageBreak({numPerPage:this.value})" name="numPerPage">   

                //在这里附上值,从而达到你切换数量时刷新页面的效果  

        if (args["numPerPage"]) form[DWZ.pageInfo.numPerPage].value = args["numPerPage"];  

        if (args["orderField"]) form[DWZ.pageInfo.orderField].value = args["orderField"];  

        if (args["orderDirection"] && form[DWZ.pageInfo.orderDirection]) form[DWZ.pageInfo.orderDirection].value = args["orderDirection"];  

    }  

       

    return form;  

}

以上代码转载自:https://blog.csdn.net/java7star/article/details/9254569 

 

由此,我们给 navTabPageBreak(args,rel)函数传入页面内需要刷新的并且带有rel属性的标签

方法调用代码:

<li><div class="buttonActive"><div class="buttonContent"><button type="button" onclick="navTabPageBreak('','qd_showRecycle'); ">刷新</button></div></div></li>

rel参数(qd_showRecycle)指定(需要刷新)的标签:

<table id='table' class="list" width="100%" layoutH="170" rel="qd_showRecycle">

 

这样,我们就可以局部刷新指定的页签了。

这篇关于DWZ局部刷新实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/419385

相关文章

python生成随机唯一id的几种实现方法

《python生成随机唯一id的几种实现方法》在Python中生成随机唯一ID有多种方法,根据不同的需求场景可以选择最适合的方案,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习... 目录方法 1:使用 UUID 模块(推荐)方法 2:使用 Secrets 模块(安全敏感场景)方法

Spring StateMachine实现状态机使用示例详解

《SpringStateMachine实现状态机使用示例详解》本文介绍SpringStateMachine实现状态机的步骤,包括依赖导入、枚举定义、状态转移规则配置、上下文管理及服务调用示例,重点解... 目录什么是状态机使用示例什么是状态机状态机是计算机科学中的​​核心建模工具​​,用于描述对象在其生命

Spring Boot 结合 WxJava 实现文章上传微信公众号草稿箱与群发

《SpringBoot结合WxJava实现文章上传微信公众号草稿箱与群发》本文将详细介绍如何使用SpringBoot框架结合WxJava开发工具包,实现文章上传到微信公众号草稿箱以及群发功能,... 目录一、项目环境准备1.1 开发环境1.2 微信公众号准备二、Spring Boot 项目搭建2.1 创建

IntelliJ IDEA2025创建SpringBoot项目的实现步骤

《IntelliJIDEA2025创建SpringBoot项目的实现步骤》本文主要介绍了IntelliJIDEA2025创建SpringBoot项目的实现步骤,文中通过示例代码介绍的非常详细,对大家... 目录一、创建 Spring Boot 项目1. 新建项目2. 基础配置3. 选择依赖4. 生成项目5.

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Linux在线解压jar包的实现方式

《Linux在线解压jar包的实现方式》:本文主要介绍Linux在线解压jar包的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux在线解压jar包解压 jar包的步骤总结Linux在线解压jar包在 Centos 中解压 jar 包可以使用 u

c++ 类成员变量默认初始值的实现

《c++类成员变量默认初始值的实现》本文主要介绍了c++类成员变量默认初始值,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录C++类成员变量初始化c++类的变量的初始化在C++中,如果使用类成员变量时未给定其初始值,那么它将被