求知若饥,虚心若愚

DWZ使用中遇到的坑

DWZ官方文档中关于文件上传表单的提交:

因为Ajax不支持enctype="multipart/form-data" 所以用隐藏iframe来处理无刷新表单提交. 

1
<form method="post" action="url" class="pageForm required-validate" enctype="multipart/form-data"<br> onsubmit="return iframeCallback(this, [navTabAjaxDone/dialogAjaxDone]);">

服务器端响应
DWZ-v1.2版本开始服务器返回和validateCallback格式保持一致:

1
2
3
4
5
6
7
8
{
    "statusCode":"200",
    "message":"操作成功",
    "navTabId":"",
    "rel":"",
    "callbackType":"closeCurrent",
    "forwardUrl":""
}

 第一个坑是,因为要上传文件,所以表单必须使用隐藏iframe的方式来处理,可是服务端返回的数据必须是JSON格式的,而不能使html,所以处理后的数据就不能展示了,只能说是提示操作状态。

第二个坑是,因为上传文件后在服务端分析数据后需要去展示,所以想着以弹窗的方式去展示,却发现了另外一个坑,事情是这样的:

dialog链接扩展:

<a href=”xxx” target=“dialog” [rel=“dialogId”]>

A所指向页面将会在dialog 弹出层中打开,rel标识此弹出层的ID,rel为可选项。

Html标签扩展方式示例:

1
2
3
<a href="w_dialog.html" target="dialog" rel="page2">弹出窗口</a>
<a href="demo_page1.html" target="dialog" [max=true, mask=true, maxable=true, minable=true, resizable=true,drawable=true]<br> rel="dlg_page1" title="[自定义标题]" width="800" height="480">打开窗口一</a>

关闭窗口:
在弹出窗口页面内放置<button class="close" value="关闭"></button>即可。

JS调用方法示例:

1
2
3
$.pdialog.open(url, dlgId, title);
$.pdialog.open(url, dlgId, title, options); 

也就是说要想在页面打开一个弹窗,就必须要加载一个页面,指定一个地址,不然的话就给你报错。。。为啥不能展示本地数据呢。。。好蛋疼的设计。

为了展示数据,于是乎在分析完文件数据后将结果存到了memcache中,然后返回一个Key放到了返回json中,好在可以自定义回调函数,将key放到一个连接中通过jQ模拟提交,通过另一个页面展示出来。擦,好纠结的业务逻辑。。。泪奔了。。。

自定义的回调函数:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
// 弹出被覆盖的数据
function customAjaxDone(json){
    if (json.statusCode == DWZ.statusCode.ok){
        if (json.content.toString() == "xxx"){
            DWZ.ajaxDone(json);
        } else {
            $("#xxx").attr("href", "{{ wrap_url('xxx/show_replace_data?hash=')}}" + json.content);
            $("#xxx").click();
        }
    }
    else{
        DWZ.ajaxDone(json);
    }
}

表单事件:

1
onsubmit="return iframeCallback(this, customAjaxDone);"

 

posted @   初行  阅读(7659)  评论(2编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述

点击右上角即可分享
微信分享提示