源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

window.open()实现post传递参数

  • 时间:2021-01-06 20:11 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:window.open()实现post传递参数
在实际项目中,常常遇到这样的需求,即实现子系统页面之间跳转并在新的页面打开,我所在项目组使用的是SSH框架,所以url均为类似****.action,同时还带有两参数(系统ID与系统名称),两个参数被struts拦截后存入session中,在打开的子系统页面中还有个ztree插件实现的树状菜单需要参数系统ID才能初始化,直接使用window.open(url,"_blank"),会使得url长度过长,同时还暴露一些参数。故想改用post方式提交,隐藏提交过程中参数的传递。首先想到ajax提交,但是两个参数的传递会存在问题,ajax提交与window.open()会使得action走两遍,因此舍去。后又重新认真看了window.open()的API,链接地址[url=http://www.w3school.com.cn/jsref/met_win_open.asp]http://www.w3school.com.cn/jsref/met_win_open.asp[/url]。window.open()默认是get提交方式,想要实现post提交方式,还得另想它法。参考[url=http://www.1sucai.cn/article/32826.htm]http://www.1sucai.cn/article/32826.htm[/url],这里介绍了一种方法。也是常被采用的方法。我根据实际情况略作修改:
[u]复制代码[/u] 代码如下:
function openPostWindow(url, name, data1, data2){     var tempForm = document.createElement("form");     tempForm.id = "tempForm1";     tempForm.method = "post";     tempForm.action = url;     tempForm.target=name;     var hideInput1 = document.createElement("input");     hideInput1.type = "hidden";     hideInput1.name="xtid";     hideInput1.value = data1;     var hideInput2 = document.createElement("input");     hideInput2.type = "hidden";     hideInput2.name="xtmc";     hideInput2.value = data2;     tempForm.appendChild(hideInput1);     tempForm.appendChild(hideInput2);     if(document.all){         tempForm.attachEvent("onsubmit",function(){});        //IE     }else{         var subObj = tempForm.addEventListener("submit",function(){},false);    //firefox     }     document.body.appendChild(tempForm);     if(document.all){         tempForm.fireEvent("onsubmit");     }else{         tempForm.dispatchEvent(new Event("submit"));     }     tempForm.submit();     document.body.removeChild(tempForm); } //function openWindow(name){ //    window.open("",name); //}
 openPostWindow()函数中的参数个数根据实际需要自行修改。data1与data2为action需要传递的参数。此外,此处还需考虑Javascript事件浏览器兼容问题。我这里注释了function openWindow(),不然会多打开一个空白页面(about:blank)。这样基本满足需求了。 以上就是本文分享的全部内容了,希望大家能够喜欢。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部