window.open()使⽤⽅法以及传参数的问题总结
⼀、window.open()⽀持环境:
JavaScript1.0+/JScript1.0+/Nav2+/IE3+/Opera3+
⼆、基本语法:
window.open(pageURL,name,parameters)
其中:
pageURL 为⼦窗⼝路径
name 为⼦窗⼝句柄
parameters 为窗⼝参数(各参数⽤逗号分隔)
三、⽰例:
<SCRIPT>
<!--
window.open ('page.html','newwindow','height=100,width=400,top=0,left=0,toolbar=no,menubar=no,scrollbars=no,
resizable=no,location=no, status=no')
//写成⼀⾏
-->
</SCRIPT>
  脚本运⾏后,page.html将在新窗体newwindow中打开,宽为100,⾼为400,距屏顶0象素,屏左0象素,⽆⼯具条,⽆菜单条,⽆滚动条,不可调整⼤⼩,⽆地址栏,⽆状态栏。请对照。
  上例中涉及的为常⽤的⼏个参数,除此以外还有很多其他参数,请见四。
四、各项参数
  其中yes/no也可使⽤1/0;pixel value为具体的数值,单位象素。
参数 | 取值范围 | 说明
alwaysLowered | yes/no | 指定窗⼝隐藏在所有窗⼝之后
alwaysRaised | yes/no | 指定窗⼝悬浮在所有窗⼝之上
depended | yes/no | 是否和⽗窗⼝同时关闭
directories | yes/no | Nav2和3的⽬录栏是否可见
height | pixel value | 窗⼝⾼度
hotkeys | yes/no | 在没菜单栏的窗⼝中设安全退出热键
innerHeight | pixel value | 窗⼝中⽂档的像素⾼度
innerWidth | pixel value | 窗⼝中⽂档的像素宽度
location | yes/no | 位置栏是否可见
menubar | yes/no | 菜单栏是否可见
outerHeight | pixel value | 设定窗⼝(包括装饰边框)的像素⾼度
outerWidth | pixel value | 设定窗⼝(包括装饰边框)的像素宽度
resizable | yes/no | 窗⼝⼤⼩是否可调整
screenX | pixel value | 窗⼝距屏幕左边界的像素长度
screenY | pixel value | 窗⼝距屏幕上边界的像素长度
scrollbars | yes/no | 窗⼝是否可有滚动栏
titlebar | yes/no | 窗⼝题⽬栏是否可见
toolbar | yes/no | 窗⼝⼯具栏是否可见
Width | pixel value | 窗⼝的像素宽度
z-look | yes/no | 窗⼝被激活后是否浮在其它窗⼝之上
=====================================================
【1、最基本的弹出窗⼝代码】
  其实代码⾮常简单:
<SCRIPT LANGUAGE="javascript">
<!--
window.open ('page.html')
-->
</SCRIPT>
  因为着是⼀段javascripts代码,所以它们应该放在<SCRIPT LANGUAGE="javascript">标签和</script>之间。<!-- 和 -->是对⼀些版本低的浏览器起作⽤,在这些⽼浏览器中不会将标签中的代码作为⽂本显⽰出来。要养成这个好习惯啊。
  Window.open ('page.html') ⽤于控制弹出新的窗⼝page.html,如果page.html不与主窗⼝在同⼀路径下,前⾯应写明路径,绝对路径()和相对路径(../)均可。⽤单引号和双引号都可以,只是不要混⽤。
  这⼀段代码可以加⼊HTML的任意位置,<head>和</head>之间可以,<body>间</body>也可以,越前越早执⾏,尤其是页⾯代码长,⼜想使页⾯早点弹出就尽量往前放。
【2、经过设置后的弹出窗⼝】
  下⾯再说⼀说弹出窗⼝的设置。只要再往上⾯的代码中加⼀点东西就可以了。
  我们来定制这个弹出的窗⼝的外观,尺⼨⼤⼩,弹出的位置以适应该页⾯的具体情况。
<SCRIPT LANGUAGE="javascript">
<!--
window.open ('page.html', 'newwindow', 'height=100, width=400, top=0,left=0, toolbar=no, menubar=no, scrollbars=no,
resizable=no,location=no, status=no')
弹出窗口代码编写//写成⼀⾏
-->
</SCRIPT>
参数解释:
<SCRIPT LANGUAGE="javascript"> js脚本开始;
window.open 弹出新窗⼝的命令;
'page.html' 弹出窗⼝的⽂件名;
'newwindow' 弹出窗⼝的名字(不是⽂件名),⾮必须,可⽤空''代替;
height=100 窗⼝⾼度;
width=400 窗⼝宽度;
top=0 窗⼝距离屏幕上⽅的象素值;
left=0 窗⼝距离屏幕左侧的象素值;
toolbar=no 是否显⽰⼯具栏,yes为显⽰;
menubar,scrollbars 表⽰菜单栏和滚动栏。
Resizable=no 是否允许改变窗⼝⼤⼩,yes为允许;
location=no 是否显⽰地址栏,yes为允许;
status=no 是否显⽰状态栏内的信息(通常是⽂件已经打开),yes为允许;
</SCRIPT> js脚本结束
【3、⽤函数控制弹出窗⼝】
  下⾯是⼀个完整的代码。
<html>
<head>
<script LANGUAGE="JavaScript">
<!--
function openwin() { window.open ("page.html", "newwindow", "height=100, width=400, toolbar=no, menubar=no, scrollbars=no, resizable=no, location=no, status=no")
//写成⼀⾏
}
//-->
</script>
</head>
<body onload="openwin()">
…任意的页⾯内容…
</body>
</html>
这⾥定义了⼀个函数openwin(),函数内容就是打开⼀个窗⼝。在调⽤它之前没有任何⽤途。
怎么调⽤呢?
⽅法⼀:<body onload="openwin()"> 浏览器读页⾯时弹出窗⼝;
⽅法⼆:<body onunload="openwin()"> 浏览器离开页⾯时弹出窗⼝;
⽅法三:⽤⼀个连接调⽤:
<a href="#" onclick="openwin()">打开⼀个窗⼝</a>
注意:使⽤的"#"是虚连接。
⽅法四:⽤⼀个按钮调⽤:
<input type="button" onclick="openwin()" value="打开窗⼝">
【4、同时弹出2个窗⼝】
  对源代码稍微改动⼀下:
<script LANGUAGE="JavaScript">
<!--
function openwin()
{ window.open ("page.html", "newwindow", "height=100, width=100, top=0,left=0,toolbar=no, menubar=no, scrollbars=no, resizable=no, location=no, status=no")
//写成⼀⾏
window.open ("page2.html", "newwindow2", "height=100, width=100, top=100, left=100,toolbar=no, menubar=no, scrollbars=no, resizable=no, location=no, status=no")
//写成⼀⾏
}
//-->
</script>
  为避免弹出的2个窗⼝覆盖,⽤top和left控制⼀下弹出的位置不要相互覆盖即可。最后⽤上⾯说过的四
种⽅法调⽤即可。
注意:2个窗⼝的name(newwindows和newwindow2)不要相同,或者⼲脆全部为空。OK?
【5、主窗⼝打开⽂件1.htm,同时弹出⼩窗⼝page.html】
  如下代码加⼊主窗⼝<head>区:
<script language="javascript">
<!--
function openwin()
{window.open("page.html","","width=200,height=200")
}
//-->
</script>
  加⼊<body>区:
<a href="1.htm" onclick="openwin()">open</a>即可。
【6、弹出的窗⼝之定时关闭控制】
  下⾯我们再对弹出的窗⼝进⾏⼀些控制,效果就更好了。如果我们再将⼀⼩段代码加⼊弹出的页⾯(注意是加⼊到page.html的HTML 中,可不是主页⾯中,否则…),让它10秒后⾃动关闭是不是更酷了?
  ⾸先,将如下代码加⼊page.html⽂件的<head>区:
<script language="JavaScript">
function closeit()
{setTimeout("self.close()",10000) //毫秒}
</script>
  然后,再⽤<body onload="closeit()"> 这⼀句话代替page.html中原有的<BODY>这⼀句就可以了。(这⼀句话千万不要忘记写啊!这⼀句的作⽤是调⽤关闭窗⼝的代码,10秒钟后就⾃⾏关闭该窗⼝。)
【7、在弹出窗⼝中加上⼀个关闭按钮】
<FORM>
<INPUT TYPE='BUTTON' VALUE='关闭' onClick='window.close()'>
</FORM>
  呵呵,现在更加完美了!
【8、内包含的弹出窗⼝-⼀个页⾯两个窗⼝】
  上⾯的例⼦都包含两个窗⼝,⼀个是主窗⼝,另⼀个是弹出的⼩窗⼝。
  通过下⾯的例⼦,你可以在⼀个页⾯内完成上⾯的效果。
<html>
<head>
<SCRIPT LANGUAGE="JavaScript">
function openwin()
{OpenWindow=window.open("", "newwin", "height=250, width=250,toolbar=no,scrollbars="+scroll+",menubar=no");
//写成⼀⾏
OpenWindow.document.write("<TITLE>例⼦</TITLE>")
OpenWindow.document.write("<BODY BGCOLOR=#ffffff>")
OpenWindow.document.write("<h1>Hello!</h1>")
OpenWindow.document.write("New window opened!")
OpenWindow.document.write("</BODY>")
OpenWindow.document.write("</HTML>")
OpenWindow.document.close()}
</SCRIPT>
</head>
<body>
<a href="#" onclick="openwin()">打开⼀个窗⼝</a>
<input type="button" onclick="openwin()" value="打开窗⼝">
</body>
</html>
  看看 OpenWindow.document.write()⾥⾯的代码不就是标准的HTML吗?只要按照格式写更多的⾏即可。千万注意多⼀个标签或少⼀个标签就会出现错误。记得⽤OpenWindow.document.close()结束啊。
【9、终极应⽤--弹出的窗⼝之Cookie控制】
  回想⼀下,上⾯的弹出窗⼝虽然酷,但是有⼀点⼩⽑病(沉浸在喜悦之中,⼀定没有发现吧?)⽐如你将上⾯的脚本放在⼀个需要频繁经过的页⾯⾥(例如⾸页),那么每次刷新这个页⾯,窗⼝都会弹出⼀次,是不是⾮常烦⼈?:-(有解决的办法吗?Yes! ;-) Follow me.
  我们使⽤cookie来控制⼀下就可以了。
  ⾸先,将如下代码加⼊主页⾯HTML的<HEAD>区:
<script>
function openwin()
{window.open("page.html","","width=200,height=200")}
function get_cookie(Name)
{var search = Name + "="
var returnvalue = "";
if (kie.length > 0) {
offset = kie.indexOf(search)
if (offset != -1) {
offset += search.length
end = kie.indexOf(";", offset);
if (end == -1)
end = kie.length;
returnvalue=kie.substring(offset,end))
}
}
return returnvalue;
}
function loadpopup(){
if (get_cookie('popped')==''){
openwin()
}
}
</script>
  然后,⽤<body onload="loadpopup()">(注意不是openwin⽽是loadpop啊!)替换主页⾯中原有的<BODY>这⼀句即可。你可以试着刷新⼀下这个页⾯或重新进⼊该页⾯,窗⼝再也不会弹出了。真正的Pop-Only-Once!
  写到这⾥弹出窗⼝的制作和应⽤技巧基本上算是完成了,俺也累坏了,⼀⼝⽓说了这么多,希望对正在制作⽹页的朋友有所帮助俺就⾮常欣慰了。
  需要注意的是,JS脚本中的的⼤⼩写最好前后保持⼀致。
再来是⼀个⼦窗⼝向⽗窗⼝赋值的例⼦
test.htm打开test1.htm
CODE:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"[url]/TR/html4/loose.dtd[/url]">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>test.htm</title>
<script language="javascript">
function winopen(){
window.open("test1.htm");
}
</script>
</head>
<body>
<form name="form1" method="post" action="">
<input type="submit" name="Submit" value="open" onClick="winopen()">
<input name="txtTest" type="text" id="txtTest" value="Test">
</form>
</body>
</html>
test1.htm
CODE:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"[url]/TR/html4/loose.dtd[/url]">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>test1.htm</title>
<script language="javascript">
function change(){
var o=window.opener;
var ElementByIdx("text1");
if (o){
var otxt=ElementByIdx("txtTest");
if(otxt){otxt.value=txt.value;}
}
}
</script>
</head>
<body>
<form name="form1" method="post" action="">
<input name="text1" type="text" id="text1">
<input name="Change" type="submit" id="Change" value="change" onClick="change()">
</form>
</body>
</html>javascript实现弹出窗⼝永远居中
function ShowDialog(url)
{
var  iWidth=600; //模态窗⼝宽度
var  iHeight=500;//模态窗⼝⾼度
var  iTop=(window.screen.height-iHeight)/2;
var  iLeft=(window.screen.width-iWidth)/2;
window.open(url,"Detail",
"Scrollbars=yes,Toolbar=no,Location=no,Direction=no,Resizeable=no,  Width="+iWidth+" ,Height="+iHeight+",top="+iTop+",left="+iLeft) }
在我⾃⼰的具体应⽤中,重新写了下赋值⽤的javascript函数
function senddata(){
var o=window.opener;
if(!o) return false;
var v_name=new Array("dwbh","dwmc","frdbmc","dwxz","dwdz",
"dwjj","xxly","hylx","zyyw","yzbm",
"dwzh","hyljjf","dwkhh","frsfz","lxr",
"lxdh","lxrxb","lxrszbm","lxrcz","lxrmail",
"lxryddh","lxrzw"
);
for(i=0;i<v_name.length;i++){
var txt = ElementByIdx(v_name[i]);
var otxt = ElementByIdx(v_name[i]);
if(!txt||!otxt) return false;
otxt.value=txt.value;
}
return true;
}
由于需要传递的参数很多,⼀个⼀个来太⿇烦了,⽤var v_name=new Array创建了⼀个数组,把⽗窗⼝中需要赋值的对象名列举出来,这样使⽤时要保证⼦窗⼝有相同名称的对象,并且对象中保有需要赋值的数据。
⼦窗⼝中的数据赋值(这是JSP)
String[] sqlname={"dwbh","dwmc","frdbmc","dwxz","dwdz",