不管是弹出一个DIV还是弹出一个窗口都可以,我把id给到这个窗口,然后这个窗口加载一个页面(a.cgi),然后显示出来内容,有个表单,提交后窗口关闭,刷新之前的页面
常用两种返回方法:
1.window.showModalDialog(url,args,dialogattrs)
参数说明:
url:弹出页面地址
agrs:主窗口传给对话框的参数,可以是任意类型(数组也可以)
dialogattrs:弹出窗口的样式参数
模式对话框用法:
主窗口:var value =window.showModalDialog('test.jsp',strs,'resizable:yes');
弹出框中通过window.returnValue设置返回值。
2。window.open:
【父窗口】毕陆带
代码如下:
<script>
function show_child()
{
var child=window .open("child.html","child","height=200,width=400,status=yes,toolbar=no,menubar=no,location=no");
/* if(!child.closed)
{
if(!window .close())
{
var textValue = frm.txt.value; parent.frm0.txt0.value = textValue;
}
else
{
window .close();
child.close();
}
}*/
}
</script>
<a href="javascript:show_child();">打开子窗口</a>
<form name=frm0>
<input type="text" name="txt0" id="txt0"> //注意这里一定要写ID属性不然FF下取不到值
</form>
【子窗口】
代码如下:
<script>
function choseItem()
{
var v="";
var check_item = document.frm.item;
for(i=0;i<check_item.length;i++)
{
if(check_item[i].checked)
{ 手芦
v+=","+check_item[i].value;
}
document.frm.txt.value=v.replace(/^,{1}/,""); 悉橘
}
}
function foo()
{
window .close();
window .opener.document.getElementById("txt0").value=document.getElementById("txt").value
}
</script>
<body>
<form name=frm>
<input type=checkbox name=item value=1 onclick="choseItem();">a
<input type=checkbox name=item value=2 onclick="choseItem();">b
<input type=checkbox name=item value=3 onclick="choseItem();">c
<input type=checkbox name=item value=4 onclick="choseItem();">d
<input type=text name="txt" id="txt">
</form>
<input type=button value="关闭" onclick="foo();">
</body>
//这是父页面所需脚本,把你的ID传进来
function ShowDialog(ID) {
//生成一段随机数字,如果两次传递的同一个ID的话,弹出的页面是不会刷新的,有了随机数就能刷新了
var temp = "";
for (var i = 0; i < 10; i++) {
temp += parseInt(Math.random() * 10);
}
//弹出模式窗体 三个参数
//第一个是路径,可以是你的CGI路径
//第二个是隐性参数,一般是用来在弹出页面判断是由什么方式打开的,如果是直接打开的弹出页面,是不会有这个参数的
//第三个参数是弹出窗口的参数,高、宽、滚动条高如
var rv = window.showModalDialog("YourWebPage.html?fk=" + temp + "&id=" + ID, "lock", "dialogHeight:130px;dialogWidth:516px;scroll:yes;");
//判断弹出页面的返回参数,然后跳转至当前页面,相当于刷新
if (rv == "jump")
window.location = "LocalWebPage.html";
}
//以下是弹出页面 所需要写的脚本
window.onload = function () {
var str = window.dialogArguments;
if (str != "lock") {
while (1 == 1) {
alert("请勿直接打开该页面!");
}
}
}
//以下是执行完你的cgi以后使用的脚本
window.returnValue = 'jump';this.close();
//补充,如果弹出页面有回传事件的话,在head中间补上<base target="_self" />,不然会弹出新页面的,表单是需要回传的,所以,桥困请你加上
==================================================================
以下是实例,请将页面保存为A.html和B.html,纯手写
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"戚消启>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>父页面</title>
<script type="text/javascript">
function ShowDialog(ID) {
var temp = "";
for (var i = 0; i < 10; i++) {
temp += parseInt(Math.random() * 10);
}
var rv = window.showModalDialog("B.html?fk=" + temp + "&id=" + ID, "lock", "dialogHeight:130px;dialogWidth:516px;scroll:yes;");
if (rv == "jump")
{
alert("这个页面要刷新了!")
window.location = "A.html";
}
}
</script>
</head>
<body>
<button onclick="ShowDialog(1)">弹出</button>
</body>
</html>
==================================================================
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>弹出页面</title>
<base target="_self" />
<script type="text/javascript">
window.onload = function () {
var str = window.dialogArguments;
if (str != "lock") {
while (1 == 1) {
alert("请勿直接打开该页面!");
}
}
}
function closePage()
{
alert('本页面执行完毕!');window.returnValue = 'jump';this.close();
}
</script>
</head>
<body>
<div>父页面问号后面的值,你应该会获取吧?</div>
<button onclick="closePage()">关闭</button>
</body>
</html>
可以在原页面上插空者入一个iframe对象,一开始是隐藏的,然后让它显示。在表单提交后,通知父窗口将其隐春扰藏,比如在a.cgi的提交事件中写入:
parent.document.getElementById("cgi_page").style.display="none";
parent.window.location.reload();
本来这种需求扒亏旦用ajax是最好的。如果是ajax,那就是另外一种做法。一般是弹出一个div,在里面做一个表单,表单中有一个button,点这个button之后就向服务器发送数据,然后隐藏该div。
这样的话由于都在同一个页面上,所以提交后就不用再引用parent。
这个最好用弹出窗口会简单多了告帆,只塌弯要在弹出窗口的提交事件里向页面输出js关闭代码的同时刷新一下父级页面就可以了,代码袜衫雹如下:
parent.location.reload();