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;pixelvalue为具体的数值,单位象素。
参数|取值范围|说明
alwaysLowered|yes/no|指定窗⼝隐藏在所有窗⼝之后
alwaysRaised|yes/no|指定窗⼝悬浮在所有窗⼝之上
depended|yes/no|是否和⽗窗⼝同时关闭
directories|yes/no|Nav2和3的⽬录栏是否可见
height|pixelvalue|窗⼝⾼度
hotkeys|yes/no|在没菜单栏的窗⼝中设安全退出热键
innerHeight|pixelvalue|窗⼝中⽂档的像素⾼度
innerWidth|pixelvalue|窗⼝中⽂档的像素宽度
location|yes/no|位置栏是否可见
menubar|yes/no|菜单栏是否可见
outerHeight|pixelvalue|设定窗⼝(包括装饰边框)的像素⾼度
outerWidth|pixelvalue|设定窗⼝(包括装饰边框)的像素宽度
resizable|yes/no|窗⼝⼤⼩是否可调整
screenX|pixelvalue|窗⼝距屏幕左边界的像素长度
screenY|pixelvalue|窗⼝距屏幕上边界的像素长度
scrollbars|yes/no|窗⼝是否可有滚动栏
titlebar|yes/no|窗⼝题⽬栏是否可见
toolbar|yes/no|窗⼝⼯具栏是否可见
Width|pixelvalue|窗⼝的像素宽度
z-look|yes/no|窗⼝被激活后是否浮在其它窗⼝之上
【1、最基本的弹出窗⼝代码】
  其实代码⾮常简单:<SCRIPTLANGUAGE="javascript">
<!--
window.open('page.html')
-
->
</SCRIPT因为着是⼀段javascripts代码,所以它们应该放在<SCRIPTLANGUAGE="javascript">标签和</script>之间。<!--和-->是对⼀些版本低的浏览器起作⽤,在这些⽼浏览器中不会将标签中的代码作为⽂本显⽰出来。要养成这个好习惯啊。
  Window.open('page.html')⽤于控制弹出新的窗⼝page.html,如果page.html不与主窗⼝在同⼀路径下,前⾯应写明路径,绝对路径()和相对路径(../)均可。⽤单引号和双引号都可以,只是不要混⽤。
  这⼀段代码可以加⼊HTML的任意位置,<head>和</head>之间可以,<body>间</body>也可以,越前越早执⾏,尤其是页⾯代码长,⼜想使页⾯早点弹出就尽量往前放。
【2、经过设置后的弹出窗⼝】
下⾯再说⼀说弹出窗⼝的设置。只要再往上⾯的代码中加⼀点东西就可以了。
我们来定制这个弹出的窗⼝的外观,尺⼨⼤⼩,弹出的位置以适应该页⾯的具体情况。<SCRIPTLANGUAGE="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>参数解释:
<SCRIPTLANGUAGE="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>
<scriptLANGUAGE="JavaScript">
<!--
functionopenwin(){window.open("page.html","newwindow","height=100,width=400,toolbar=no,menubar=no,scrollbars=no,resizable=no,location=no,status=no") //写成⼀⾏
}
//-->
</script>
</head>
<bodyonload="openwin()">
…任意的页⾯内容…
</body>
</html>
这⾥定义了⼀个函数openwin(),函数内容就是打开⼀个窗⼝。在调⽤它之前没有任何⽤途。
怎么调⽤呢?
⽅法⼀:<bodyonload="openwin()">浏览器读页⾯时弹出窗⼝;
⽅法⼆:<bodyonunload="openwin()">浏览器离开页⾯时弹出窗⼝;
⽅法三:⽤⼀个连接调⽤:
<ahref="#"onclick="openwin()">打开⼀个窗⼝</a>
注意:使⽤的"#"是虚连接。
⽅法四:⽤⼀个按钮调⽤:
<inputtype="button"onclick="openwin()"value="打开窗⼝">
【4、同时弹出2个窗⼝】
对源代码稍微改动⼀下:
<scriptLANGUAGE="JavaScript">
<!--
functionopenwin()
{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>区:
<scriptlanguage="javascript">
<!--
functionopenwin()
{window.open("page.html","","width=200,height=200")
}
//-->
</script>
加⼊<body>区:
<ahref="1.htm"onclick="openwin()">open</a>即可。
【6、弹出的窗⼝之定时关闭控制】
下⾯我们再对弹出的窗⼝进⾏⼀些控制,效果就更好了。如果我们再将⼀⼩段代码加⼊弹出的页⾯(注意是加⼊到page.html的HTML中,可不是主页⾯中,否则…),让它10秒后⾃动关闭是不是更酷了?
⾸先,将如下代码加⼊page.html⽂件的<head>区:
<scriptlanguage="JavaScript">
functioncloseit()
{setTimeout("self.close()",10000)//毫秒}
</script>
然后,再⽤<bodyonload="closeit()">这⼀句话代替page.html中原有的<BODY>这⼀句就可以了。(这⼀句话千万不要忘记写啊!这⼀句的作⽤是调⽤关闭窗⼝的代码,10秒钟后就⾃⾏关闭该窗⼝。)
【7、在弹出窗⼝中加上⼀个关闭按钮】
<FORM>
<INPUTTYPE='BUTTON'VALUE='关闭'onClick='window.close()'>
</FORM>
呵呵,现在更加完美了!
【8、内包含的弹出窗⼝-⼀个页⾯两个窗⼝】
上⾯的例⼦都包含两个窗⼝,⼀个是主窗⼝,另⼀个是弹出的⼩窗⼝。
通过下⾯的例⼦,你可以在⼀个页⾯内完成上⾯的效果。
<html>
<head>
<SCRIPTLANGUAGE="JavaScript">
functionopenwin()
{OpenWindow=window.open("","newwin","height=250,width=250,toolbar=no,scrollbars="+scroll+",menubar=no");
/
write的返回值/写成⼀⾏
OpenWindow.document.write("<TITLE>例⼦</TITLE>")
OpenWindow.document.write("<BODYBGCOLOR=#ffffff>")
OpenWindow.document.write("<h1>Hello!</h1>")
OpenWindow.document.write("Newwindowopened!")
OpenWindow.document.write("</BODY>")
OpenWindow.document.write("</HTML>")
OpenWindow.document.close()}
</SCRIPT>
</head>
<body>
<ahref="#"onclick="openwin()">打开⼀个窗⼝</a>
<inputtype="button"onclick="openwin()"value="打开窗⼝">
</body>
</html>
看看OpenWindow.document.write()⾥⾯的代码不就是标准的HTML吗?只要按照格式写更多的⾏即可。千万注意多⼀个标签或少⼀个标签就会出现错误。记得⽤OpenWindow.document.close()结束啊。
【9、终极应⽤--弹出的窗⼝之Cookie控制】
回想⼀下,上⾯的弹出窗⼝虽然酷,但是有⼀点⼩⽑病(沉浸在喜悦之中,⼀定没有发现吧?)⽐如你将上⾯的脚本放在⼀个需要频繁经过的页⾯⾥(例如⾸页),那么每次刷新这个页⾯,窗⼝都会弹出⼀次,是不是⾮常烦⼈?:-(有解决的办法吗?Yes!;-)Followme.
我们使⽤cookie来控制⼀下就可以了。
⾸先,将如下代码加⼊主页⾯HTML的<HEAD>区:
<script>
functionopenwin()
{window.open("page.html","","width=200,height=200")}
functionget_cookie(Name)
{varsearch=Name+"="
varreturnvalue="";
kie.length>0){
kie.indexOf(search)
if(offset!=-1){
offset+=search.length
kie.indexOf(";",offset);
if(end==-1)
kie.length;
returnvalue=kie.substring(offset,end))
}
}
returnreturnvalue;
}
functionloadpopup(){
if(get_cookie('popped')==''){
openwin()
}
}
</script>
然后,⽤<bodyonload="loadpopup()">(注意不是openwin⽽是loadpop啊!)替换主页⾯中原有的<BODY>这⼀句即可。你可以试着刷新⼀下这个页⾯或重新进⼊该页⾯,窗⼝再也不会弹出了。真正的Pop-Only-Once!
写到这⾥弹出窗⼝的制作和应⽤技巧基本上算是完成了,俺也累坏了,⼀⼝⽓说了这么多,希望对正在制作⽹页的朋友有所帮助俺就⾮常欣慰了。
需要注意的是,JS脚本中的的⼤⼩写最好前后保持⼀致。
【10、关闭弹出窗⼝时候刷新⽗窗体】
引⽤下⾯的JS⽅法,实现关闭弹出窗⼝刷新⽗窗体
javascript:opener.location.href=opener.location.href;opener=null;window.close()

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。