windowopen传值到jsp_window.open()页面之间函数传值

项目中遇到的问题,使用window.open()开一个页面之后,cookie会消失,所以无法一键切肤不管作用,解决方案如下:

window.open()总结:

window.open("sUrl","sName","sFeature","bReplace");

sUrl:可选项。字符串(String)。指定要被加载的HTML文档的URL地址。假如无指定值,则about:blank的新窗口会被显示。

sName:可选项。字符串(String)。指定打开的窗口的名字。这个名字可以用于form或a对象的TARGET属性。此名字也可以使用下列通用名称:_media:IE6.0在浏览器左边的媒体面板内打开sUrl。

_blank:在新窗口中打开sUrl。

_parent:在当前框架的父框架内打开。假如当前框架无父框架,此参数值等同于_self。

_search:IE5.0在浏览器左边的搜索面板内打开sUrl。

_self:sUrl在当前窗口中打开,覆盖当前文档。

_top:在所有框架之外的最顶层窗口中打开sUrl。假如当前窗口无框架结构,此参数值等同于_self。

sFeatures:可选项。字符串(String)。指定窗口装饰样式。使用下面的值。多个之间用逗号隔开。只有当新的浏览器窗口被建立时,此参数的设置才会发生作用。channelmode={yes|no|1|0}指定是否将窗口显示为频道模式。默认值为no。

directories={yes|no|1|0}指定是否显示「链接」按钮。默认值为yes。

fullscreen={yes|no|1|0}指定是否以全屏方式显示窗口。默认值为no。要小心使用全屏模式,因为这种模式会隐藏浏览器窗口的标题栏和菜单。如果没有在页面内提供关闭窗口的功能,用户可以使用ALT+F4快捷键关闭窗口。

height=number设置窗口的高度。最小值为100。

left=number设置窗口左上角相对于桌面的横坐标。单位为像素(px)。

width=number设置窗口的宽度。最小值为100。

top=number设置窗口左上角相对于桌面的纵坐标。单位为像素(px)。

location={yes|no|1|0}设置是否显示浏览器窗口的地址栏。默认值为yes。

menubar={yes|no|1|0}设置是否显示浏览器窗口的菜单栏。默认值为yes。

resizable={yes|no|1|0}设置窗口是否允许被用户改变尺寸。默认值为yes。

scrollbars={yes|no|1|0}设置窗口是否可以具有滚动条。默认值为yes。

status={yes|no|1|0}设置是否显示浏览器窗口的状态栏。默认值为yes。

titlebar=

{yes|no|1|0}设置是否显示浏览器窗口的标题栏。除非调用程序是HTML应用程式(HTA)或被信任的对话框,否则此参数将被忽略。默认值为

yes。toolbar={yes|no|1|0}设置是否显示浏览器窗口的工具条。默认值为yes。

bReplace:可选项。布尔值(Boolean)。false|true。false:新打开的文档覆盖历史列表里的当前文档。true:文新打开的文档被简单的添加到历史列表的最后。

返回值:

oNewWindow:对象(Element)。返回对新的window对象的引用。

实例:

$("#terminalControl").bind("click",function(){

$("#terminalControl").removeClass();

$("#terminalControl").addClass("btn_pointToPint" + $.cookie("color"));//先清除class,再增加class,此class我准备在window.open的页面需要获取到

var keyValue = $("#gridTable").jqGridRowValue("id");var rowData = $("#gridTable").jqGrid('getRowData',keyValue);if(checkedRow(keyValue)){

$(this).attr("disabled","disabled");

$.ajax({async:true,

url:'${basePath}/ptp/ptpAction_ipValid.do',

data:{ip:getcellTitle(rowData.ip)},

beforeSend:function(){

$("#terminalControl").attr("value",'');

},

success:function(responseText){

$("#terminalControl").attr("value",'');

$("#terminalControl").removeAttr("disabled");var obj = eval("(" + responseText + ")");if(obj.result == "success"){var resourceId="";

$.each(top.authorizeMenuData,function(i,n){if(n.text=="点对点控制"&&n.mark=="menu"||n.text=="ptpControl"&&n.mark=="menu"){

resoureId=n.id;

}

})

window.open("${basePath}/ptp/ptpAction_main.do?resourceId="+resoureId,"_black","toolbar=yes, menubar=yes, scrollbars=yes, resizable=yes,location=no, status=yes",false);

}else if(obj.result == "multi"){var ip = $("#ip_input").val();

dialogOpen({

id:"ptp",

title:"在线设备",

url:"/ptp/ptpAction_listUI.do?ip="+ip,

width:"500px",

height:"1000px",

offset:"rb",

btn:null})

}else if(obj.result == "connectServerFail"){

dialogMsg("连接服务器失败!",0);

}else if(obj.result == "analyzeError"){

dialogMsg("服务配置解析数据失败!",0);

}else if(obj.result == "notOnline"){

dialogMsg("该设备不在线!",0);

}else{

dialogMsg('',0);

}

}

});

}return false;

});

从window.open的页面获取到button的class:

var color = window.opener.document.getElementById("terminalControl").className.split(" ")[1];

$("body").addClass(color);

注意:只能从window.open的url页面才能获取到:window.opener,这样就可以获取到window.open的父级页面上的任何元素。

方法:

1、在父级页面 test.aspx 的点击按钮触发 ,然后 :

function showItem() {var win = window.open("test2.aspx",null,"height=300,width=450, Left=300px,Top=20px, menubar=no,titlebar=no,scrollbar=no,toolbar=no, status=no,location=no");

}

2: 在子级页面test2.aspx的点击 按钮触发,然后:

function check() {

window.opener.document.getElementById("txtId").value=id;

window.opener.document.getElementById("txtName").value=name;

}

这样,父级页面的document.getElementById("txtId") 和 document.getElementById("txtName") 2个控件就可以得到子级页面的返回值。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Window.open方法可以接受一个URL参数作为参数,可以使用URL查询字符串形式传递参数给子页面。例如:Window.open('http://example.com/page.html?param1=value1&param2=value2')。 ### 回答2: 在JSP,可以使用JavaScript的window.open方法打开一个新的浏览器窗口或标签页。要向子页面传递参数,可以通过URL的查询字符串部分传递。 以下是一个示例代码,演示如何在JSP将参数传递给window.open的子页面: ```jsp <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html> <html> <head> <title>传递参数给子页面</title> <script> function openChildPage() { var parameter1 = "参数1的值"; var parameter2 = "参数2的值"; var url = "child_page.jsp?param1=" + encodeURIComponent(parameter1) + "&param2=" + encodeURIComponent(parameter2); window.open(url, "_blank"); } </script> </head> <body> <button onclick="openChildPage()">打开子页面</button> </body> </html> ``` 在上述代码,通过JavaScript的window.open方法打开了一个名为"child_page.jsp"的子页面,并传递了两个参数param1和param2。参数值通过encodeURIComponent函数进行编码,以确保特殊字符正确传递。 在子页面"child_page.jsp",可以通过获取URL的查询字符串部分来获取传递的参数值。以下是一个示例代码: ```jsp <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html> <html> <head> <title>子页面</title> </head> <body> <h1>子页面</h1> <%-- 获取参数值 --%> <% String param1 = request.getParameter("param1"); %> <% String param2 = request.getParameter("param2"); %> <p>参数1的值为: <%= param1 %> </p> <p>参数2的值为: <%= param2 %> </p> </body> </html> ``` 在上述代码,使用request.getParameter方法获取了参数param1和param2的值,并显示在子页面。 通过以上方式,可以在JSP使用window.open方法传递参数给子页面,并在子页面获取并使用这些参数值。 ### 回答3: 在JSP,可以通过使用JavaScript的方式向Window.open的子页面传递参数。下面是具体的步骤: 1. 首先,确定要传递的参数。可以使用JSP的变量或者是在页面上直接定义的值。 2. 创建一个JavaScript函数,该函数将在Window.open被调用。函数的参数与要传递的参数相对应。 3. 在Window.open使用JavaScript函数来传递参数。具体格式为:window.open("子页面URL?参数名1=参数值1&参数名2=参数值2", "_blank")。其,子页面URL是指要打开的子页面的URL,参数名和参数值是要传递的参数和对应的值。 4. 在子页面,通过JavaScript获取URL的参数。可以使用search属性来获取URL的查询参数,然后通过正则表达式或者其他方法来解析参数。 例如,要将id和name这两个参数传递给子页面,可以按照以下方式实现: 在JSP: ```jsp <% String id = "123"; String name = "张三"; %> <script> function openChildPage() { var id = "<%= id %>"; var name = "<%= name %>"; var url = "childPage.jsp?id=" + id + "&name=" + encodeURIComponent(name); window.open(url, "_blank"); } </script> <button onclick="openChildPage()">打开子页面</button> ``` 在子页面(childPage.jsp): ```html <script> var params = window.location.search.substring(1).split("&"); var id, name; for (var i = 0; i < params.length; i++) { var pair = params[i].split("="); var key = decodeURIComponent(pair[0]); var value = decodeURIComponent(pair[1]); if (key === "id") { id = value; } else if (key === "name") { name = value; } } console.log("id: " + id); console.log("name: " + name); </script> ``` 这样,就可以实现使用Window.open向子页面传递参数并在子页面获取参数的功能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值