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 | 窗口被激活后是否浮在其它窗口之上


用函数控制弹出窗口

下面是一个完整的代码。

<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="打开窗口">

如何实现在不使用window.showModalDialog 的情况下用 window.open方式 向父窗口返回值。

例如: 页面AAA.htm 用 window.open方式弹出页面 BBB.htm 。
在页面BBB.htm上选择一个值,确定关闭窗口后将选择的这个值返回到父窗口AAA.htm。
AAA.htm得到返回的值后,给本页面上的文本框赋值。


BBB.htm页面中加入下面代码:

window.opener.document.getElementById("theTextAreaId").value = document.getElemnetById("theSelectId").value ;



window.opener 的用法

window.opener 返回的是创建当前窗口的那个父窗口的引用,比如点击了a.htm上的一个链接而打开了b.htm,然后我们打算在b.htm上输入一个值然后赋予a.htm上的一个id为“name”的textbox中,就可以写为:


window.opener.document.getElementById("name").value = "输入的数据";

对于javascript中的window.opener没有很好的理解。
为什么框架中不能使用,弹出窗口的父窗口不能在框架里面的某个页面呢?那怎样通过弹出窗口操作框架中的父窗口呢?

opener.parent.frames['frameName'].document.all.input1.value

即opener这个对象为前一个窗口,可以使用window.opener.document...调用document的相关方法,例如下面的例子,插入一些table行到前一个窗口:

function taletoTb(itemStr) {  
        newRow = opener.document.all.itemTb.insertRow(opener.document.all.itemTb.rows.length);  
        rowCnt = opener.document.all.itemTb.rows.length;  
        newCell = newRow.insertCell();  
        newCell.insertAdjacentHTML('BeforeEnd','<div align="center">'+itemCode+'</div>');  
        newCell = newRow.insertCell();  
        newCell.insertAdjacentHTML('BeforeEnd','<div align="center">'+itemName+'</div>');  
        newCell = newRow.insertCell();  
        newCell.insertAdjacentHTML('BeforeEnd','<div align="center"><img src="http://www.cnblogs.com/../images/delete2.gif" width="12" height="12" onClick="userRightDel(this);"><input type="hidden" name="itembox" value='+itemCode+'></div>');  
     }  11:56 浏览 (159) 评论 (0) 分类: JavaScript 2008-02-27
缩略显示confirm用法和例子
一般用于弹出对话框(确定/否)
确定:就执行其嵌套的内容;否:则反之


<script language="javascript">  
//验证时间格式  YYYY-MM-DD/YYYY,MM,DD  
function isDate(date){  
    var regu = "^[0-9]{4}-([0-1]?)[0-9]{1}-([0-3]?)[0-9]{1}$";  
    var re   = new RegExp(regu);  
    if (date.search(re) != -1)  
        return true;  
    else 
        return false;  
}   
function sureButton(){  
   if(!confirm('真的要删除吗?删除后将无法恢复!')){  
       return;  
   }  
   //验证时间格式  YYYY-MM-DD  
 
       var startDate=document.getElementById("startDate").value;  
       var endDate=document.getElementById("endDate").value;   
       if(!isDate(startDate)){  
                  
             alert(startDate+"请输入正确的开始日期格式!如:(YYYY-MM-DD)2008-01-01");  
             return document.getElementById("startDate").focus();  
       }  
       if(!isDate(endDate)){  
             alert("请输入正确的结束日期格式!如:(YYYY-MM-DD)2008-01-01");  
             return document.getElementById("endDate").focus();  
       }  
         if(startDate==""){  
    alert("请输入开始日期");  
    return document.getElementById("startDate").focus();  
   }  
   if(endDate==""){  
    alert("请输入结束日期");  
    return document.getElementById("endDate").focus();  
   }   
   startDate=startDate.replace(new RegExp('-', 'g'),'/');  
   alert(startDate);  
   endDate=endDate.replace(new RegExp('-', 'g'),'/');  
   var startTime=new Date(startDate).getTime();  
   alert(new Date(startDate).getTime());  
   var endTime=new Date(endDate).getTime();  
   if((endTime-startTime)<0){  
    alert("结束日期必须大于开始日期");  
        return document.getElementById("endDate").focus();  
   }     
     
     
}  
</script> 


<html>   
<head>  
<meta http-equiv="Content-Language" content="zh-cn">  
<meta name="generator" content="Bluefish 1.0.7">  
<meta name="ProgId" content="FrontPage.Editor.Document">  
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">  
<title></title>  
<style type="text/css">  
  table{color: #000000; font-family: 宋体; font-size: 12px; height:12 }  
  t1{color:#008000;align:center}  
</style>  
</head>  
 
<body topmargin="0" leftmargin="0">  
 
<div align="left">  
  <table border="0" cellpadding="0" cellspacing="0" style="border-collapse: collapse" bordercolor="#111111" width="461" height="8" ;

    对于javascrīpt中的window.opener没有很好的理解。

    为什么框架中不能使用,弹出窗口的父窗口不能在框架里面的某个页面呢?那怎样通过弹出窗口操作框架中的父窗口呢?

    opener.parent.frames['frameName'].document.all.input1.value 试试这个:)



正确使用window.open返回对象的opener


众所周知JavaScript中:

var win = window.open(url,windowName,...); 的使用,

而win.opener则是指向父窗口的引用

然而,有种情况却比较特别,

假如有两个窗口window1和window2

按下列步骤执行:

var win = window.open(url,windowName,...);// (window1)

var win = window.open(url,windowName,...);//(window2)

其中先后这两次打开的子窗口的windowName一样

此时你会发现在window2中的win.opener却不是指向window2的,却是指向window1.

如果你想在子窗口关闭父窗口的话,就不正确了,因此可以修改上面的执行方法为:

var win = window.open(url,windowName,...);? (window1)

win.opener = window;

var win = window.open(url,windowName,...);? (window2)

win.opener = window;

只有这样修改才OK







通过window.showModalDialog或者.showModelessDialog弹出的页面

这种情况需要两个步骤:1 在父窗口.showModalDialog或.showModelessDialog方法的第二个参数传递window对象比如: window.showModelessDialog('a.htm',window);2 在a.htm中就可以通过window.dialogArguments获取该参数比如: window.dialogArguments.fun1();PS:子窗口可以通过设置window.returnValue设置页面返回值
比如: window.returnValue=’OK’;window.close();

strRtn=window.showModalDialog(......)










相关文章: