博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
showModalDialog()向子窗口传自定义参数(javascript提取url参数)及其他
阅读量:6573 次
发布时间:2019-06-24

本文共 3347 字,大约阅读时间需要 11 分钟。

hot3.png

事情是这样子的。

今天下午我正刷果壳刷得不亦乐乎,突然需求就下来了。

它!就!这!么!下!来!了!

172426_RKSE_1040430.jpg

客户说,我们需要打开一个新窗口来进行模糊查询,然后选择一个查询结果回填到父窗口中。

valy easy。

173255_BSQB_1040430.jpg

然后我发现那个模糊查询的页面叫agentSearch.jsp

里面的内容是这样的

function backfill(){    var val = document.getElementById("agentsearch").value;    var parWin = window.dialogArguments;    parWin.document.getElementById(" ").value = val;			    window.close();}

咦为什么getElementById参数会是空的呢

不管了可能是上一个人没写完吧,那就让我来完成它!!!

174710_rSBp_1040430.jpg

有两个页面调用过它

createsettlementmanage_search.jsp

commissionsettlement.jsp

可能这两个页面需要的查询条件都差不多吧,反正都调了同一个页面不是么

你也是这么想的对吧?

173851_g96i_1040430.jpg

呵呵。

我打开其中一个文件

呐就当我先打开的它吧

createsettlementmanage_search.jsp

...function showAgentSearch(){    var url = "<%=path%>/commission/agentSearch.jsp";    var param = "dialogWidth:400px;dialogHeight:250px;help:no;unadorned:no;resizable:no;status:no";    return window.showModalDialog(url,window,param);}...

...
代理人/经纪人:
    
    
" onclick="showAgentSearch()">    
*...

哎呦写得不错哦

呐既然id是agentcode那我在agentSearch.jsp里面填上agentcode不就好了么

果真是上一个人没写完啊啧啧啧,究竟是有多着急的事情啊连这个id都不肯加上

然后我淡定地把id给写了上去

parWin.document.getElementById("agentcode").value = val;

结果成功跑出来了。

对啊你以为呢?

175235_LArh_1040430.jpg

好了然后我打开了另一个文件

commissionsettlement.jsp

...function showAgentSearch(){    var url = "<%=path%>/commission/agentSearch.jsp";    var param = "dialogWidth:400px;dialogHeight:250px;help:no;unadorned:no;resizable:no;status:no";    return window.showModalDialog(url,window,param);}...

...
代理人/经纪人:
    
    
" onclick="showAgentSearch()">    
*...

哎呀一样的嘛,等我把东西交上去就...

等等

id为什么变成了agentname

175659_zZjO_1040430.jpg

卧槽。

怎么可以这样,人与人之间最基本的信任呢

接下来就是我们几个热烈讨论解决方案的时候了

我主张的是把agentSearch.jsp拷贝一份,改个参数,让一个文件调用这个agentSearch.jsp,另一个文件调用另一个agentSearch.jsp

简单粗暴。是的我就是这么不与世俗同流合污

093549_ZSY8_1040430.jpg

龙哥说还有一种是用div直接在当前页面显示就好,正好省的烦开一个新页面了

用w2ui或者easyui的话顺路界面还能更漂亮呢不是

听起来好有道理,不过代码要大改

094024_va5R_1040430.jpg

呵呵。

涛哥的意思是可以在showModalDialog()的时候传入一个参数parameter,当它是1的时候执行getElementById("agentcode"),当它是2的时候执行getElementById("agentname")

但是这个有一个重大问题就是,showModalDialog()只能传入三个参数sURL,vArguments,sFeatures

我说我们可以把参数放在vArguments里面啊多和谐啊水到渠成

龙哥说丫忘了我们还要回填了吧vArguments只能传父窗口的Object啊

095334_esPe_1040430.jpg

哦。

然后涛哥说我觉得我们可以在url里面放一个参数,就像这样

agentSearch.jsp?parameter=1

我和龙哥同时对其机智表示赞许并表示党国的未来还是要靠你们

100213_Z9Od_1040430.jpg

接下来就是实现了

那两个名字好长的文件只不过在url后面打个问号加个参数就不重新写了

是的我就是懒

100527_o7hN_1040430.png

现在只要改一下agentSearch.jsp就可以交差了

生活如此美好

<%String parameter=request.getParameter("parameter");%>...function backfill(){    var val = document.getElementById("agentsearch").value;    var parWin = window.dialogArguments;    var parameter = <%=parameter%>;    if (parameter == "1"){        parWin.document.getElementById("agentcode").value = val;    }else if (parameter == "2"){        parWin.document.getElementById("agentname").value = val;    }else{        alert("呵(f**k)呵(you)。");    }    window.close();}...

先在上面用request.getParameter("parameter")获取到parameter的值

或者1或者2

当然了在不可抗力的作用下有可能产生一些奇怪的结果

比如说十一点断电了

然后 var parameter = <%=parameter%>; 是将参数赋值到javascript脚本中

接下来就是执行判断了

1的话这样

parWin.document.getElementById("agentcode").value = val;

2的话这样

parWin.document.getElementById("agentname").value = val;

其他的话乱入请不要介意

那这样的话任务就算完成了

在这里我只想对那个写这份代码的前一个同学说

You silly B!

hui duan!

shen me gui!

ni ma 【哔-】!

son of bick!

There's a fire starting in my heart~ Reaching a fever piss and it's bringing me out the dark~

102924_w9Gg_1040430.jpg

Done.

PS. 以上。是的我就是要把所有的变量名都叫 parameter 来砍死我啊呵呵呵。

140435_oiYw_1040430.jpg

转载于:https://my.oschina.net/u/1040430/blog/341773

你可能感兴趣的文章
分布式缓存Redis Centos下单节点安装
查看>>
完整仿写鸿洋WanAndroid网站客户端
查看>>
2.1 ListView 源码
查看>>
一起来学SpringBoot | 第二篇:SpringBoot配置详解
查看>>
Vue的mergeOptions函数分析-下
查看>>
ES6知识点概述
查看>>
excanvas让canvas兼容ie7,8
查看>>
前端面经
查看>>
AI进入制造业 节省人工成本也能提高产品性能
查看>>
剑指offer题解
查看>>
MXRuntimeUtils,替代 [NSObject performSelector object object ]的工具
查看>>
深入理解HTTPS工作原理
查看>>
一个月面试 4 家,3 家 Offer,来看看人家是如何面试的!
查看>>
一个近乎完美基于Dubbo的微服务改造实践
查看>>
广安a货翡翠,自贡a货翡翠
查看>>
通信方式
查看>>
JavaScript-call&apply方法
查看>>
Swift之UITextField+富文本+代理传值
查看>>
Java 进阶基础知识
查看>>
我的前端笔记之 meta 篇
查看>>