(转)IE浏览器的菜单栏和工具栏原理

1、最基本的弹出窗口代码】
 其实代码非常简单:
 
 因为这是一段javascripts代码,所以它们应该放在
 参数解释:
  js脚本结束
 
 【3、用函数控制弹出窗口】
 下面是一个完整的代码:
 
 
 
 
 
 ...任意的页面内容...
 
 
   这里定义了一个函数openwin(),函数内容就是打开一个窗口。在调用它之前没有任何用途。
 怎么调用呢?
   方法一: 浏览器读页面时弹出窗口;
   方法二: 浏览器离开页面时弹出窗口;
   方法三:用一个连接调用:打开一个窗口
 注意:使用的“#”是虚连接。
   方法四:用一个按钮调用:
 
 【4、同时弹出2个窗口】
 对源代码稍微改动一下:
 
   为避免弹出的2个窗口覆盖,用top和left控制一下弹出的位置不要相互覆盖即可。最后用上面说过的四种方法调用即可。
 注意:2个窗口的name(newwindows和newwindow2)不要相同,或者干脆全部为空。OK?
 
 【5、主窗口打开文件1.htm,同时弹出小窗口page.html】
 如下代码加入主窗口区:
 
 加入区:
 open即可。
 
 【6、弹出的窗口之定时关闭控制】
 下面我们再对弹出的窗口进行一些控制,效果就更好了。如果我们再将一小段代码加入弹出的页面(注意是加入到page.html的HTML中,可不是主页面中,否则...),让它10秒后自动关闭是不是更酷了?
 首先,将如下代码加入page.html文件的区:
 
 然后,再用 这一句话代替page.html中原有的这一句就可以了。(这一句话千万不要忘记写啊!这一句的作用是调用关闭窗口的代码,10秒钟后就自行关闭该窗口。)
 
 【7、在弹出窗口中加上一个关闭按钮】
 

 
 

 呵呵,现在更加完美了!
 
 【8、内包含的弹出窗口---一个页面两个窗口】
 上面的例子都包含两个窗口,一个是主窗口,另一个是弹出的小窗口。通过下面的例子,你可以在一个页面内完成上面的效果。
 
 
 
 
 
 打开一个窗口
 
 
 
 看看OpenWindow.document.write()里面的代码不就是标准的HTML吗?只要按照格式写更多的行即可。千万注意多一个标签或少一个标签就会出现错误。记得用OpenWindow.document.close()结束啊。
 
 【9、终极应用--弹出的窗口之Cookie控制】
 回想一下,上面的弹出窗口虽然酷,但是有一点小毛病(沉浸在喜悦之中,一定没有发现吧?)比如你将上面的脚本放在一个需要频繁经过的页面里(例如首页),那么每次刷新这个页面,窗口都会弹出一次,是不是非常烦人?:-(
 有解决的办法吗?当然有!我们使用cookie来控制一下就可以了。首先,将如下代码加入主页面HTML的区:
 
   然后,用(注意不是openwin而是loadpop啊!)替换主页面中原有的这一句即可。你可以试着刷新一下这个页面或重新进入该页面,窗口再也不会弹出了。真正的Pop-Only-Once!
 
 
 一种没有边框及菜单栏、工具栏、地址栏、状态栏等的无边框窗口(CW)曾经一度很流行,被很多网站尤其是个人网站所采用,CW也有现成的源码供网友们使用,但是最初的CW使用起来很不方便,有两个JS文件,还要设置一些参数,这对一些初学者来讲是很困难的事情。所以我就有了一个想法:重新写一个全新的无边框窗口,只用一个函数实现,以供网友方便使用。
 
   我给这个全新的无边框窗口起名为NBW,NBW即No Border Window的缩写,只是想区别于CW。这个无边框窗口可以随意拖动、最小化、关闭等等,不仅在IE5/IE6中测试通过,在腾讯的TE中测试也没有问题。
 
 调用的过程如下:(noBorderWin函数是事先定义好的,后面会对函数的实现过程进行分析)
 
   noBorderWin(fileName,w,h,titleBg,moveBg,titleColor,titleWord,scr)
 
   各参数的说明如下:
   fileName :要打开的文件。
   w     :窗口的宽度(px)。
   h     :窗口的高度(px)。
   titleBg  :窗口“标题栏”的背景色以及窗口边框颜色。
   moveBg  :拖动窗口时“标题栏”的背景色以及窗口边框颜色。
   titleColor:窗口“标题栏”文字的颜色。
   titleWord :窗口“标题栏”中显示的文字。
   scr    :窗口中是否出现滚动条。取值yes/no或者1/0。
 
   我们看到,窗口样式全部在函数的参数中设置,从而保证了使用的便捷。比如,上面例子的代码如下:
   <a href=#none οnclick=noBorderWin('test.html','400','240','#000000','#333333','#CCCCCC','一个无边窗口的测试例子','yes');>点击此处将弹出NBW窗口</a>
 
   如何使用已经说完了,那么,这个函数具体是如何实现的呢?下面,我们就以直接给出源码并加以注释的方式进行讲解。为了容易区分阅读,代码部分使用灰色,注释部分使用红色。
 
   代码和注释如下:
 //--------------------------------------------------------------------------------------------------
 <script language=javascript>
 //*****定制NBW窗口中几个用到的图片的路径*****
 minimizebar="minimize.gif";   //窗口右上角最小化“按钮”的图片
 minimizebar2="minimize2.gif"; //鼠标悬停时最小化“按钮”的图片
 closebar="close.gif";         //窗口右上角关闭“按钮”的图片
 closebar2="close2.gif";       //鼠标悬停时关闭“按钮”的图片
 icon="icon.gif";              //窗口左上角的小图标
 //***************定制结束*****************
 
 //*******开始定义noBorderWin()函数********
 function noBorderWin(fileName,w,h,titleBg,moveBg,titleColor,titleWord,scr)
 {
   var contents="<html>"+ //变量contents是一个字符串变量,它是NBW窗口中的所有代码。
                "<head>"+
                "<title>"+titleWord+"</title>"+
                "<meta http-equiv=/"Content-Type/" content=/"text/html; charset=gb2312/">"+
                "<object id=hhctrl type='application/x-oleobject' classid='clsid:adb880a6-d8ff-11cf-9377-00aa003b7a11'><param name='Command' value='minimize'></object>"+ //注意这一句,是实现窗口的最小化的关键。在后面,将通过hhctrl.Click()来实现最小化。
                "</head>"+
                "<body topmargin=0 leftmargin=0 scroll=no onselectstart='return false' οndragstart='return false'>"+ //为了使窗口更加逼真,在这一句中,屏弊了拖拽事件和选取事件。
                " <table height=100% width=100% cellpadding=0 cellspacing=1 bgcolor="+titleBg+" id=mainTab>"+
                " <tr height=18 style=cursor:default; οnmοusedοwn='x=event.x;y=event.y;setCapture();mainTab.bgColor=/""+moveBg+"/";' οnmοuseup='releaseCapture();mainTab.bgColor=/""+titleBg+"/";' οnmοusemοve='if(event.button==1)self.moveTo(screenLeft+event.x-x,screenTop+event.y-y);'>"+ //在这一句中,实现了NBW窗口的任意拖拽,注意onmousedown、onmouseup和onmousemove时都“发生”了什么,仔细体会其过程。
                " <td width=18 align=center><img height=12 width=12 border=0 src="+icon+"></td>"+
                " <td width="+w+"><span style=font-size:12px;color:"+titleColor+";font-family:宋体;position:relative;top:1px;>"+titleWord+"</span></td>"+ //以上两句,将小图标和标题栏的文字写入。
                " <td width=14><img border=0 width=12 height=12 alt=最小化 src="+minimizebar+" οnmοusedοwn=hhctrl.Click(); οnmοuseοver=this.src='"+minimizebar2+"' οnmοuseοut=this.src='"+minimizebar+"'></td>"+ //通过前面提到的方法实现了窗口最小化按钮的功能。
                " <td width=13><img border=0 width=12 height=12 alt=关闭 src="+closebar+" οnmοusedοwn=self.close(); οnmοuseοver=this.src='"+closebar2+"' οnmοuseοut=this.src='"+closebar+"'></td>"+ //实现窗口关闭按钮的功能。
                " </tr>"+
                " <tr height=*>"+
                " <td colspan=4>"+
                " <iframe name=nbw_v6_iframe src="+fileName+" scrolling="+scr+" width=100% height=100% frameborder=0></iframe>"+ //在这一句中,将你要打开的文件写到iframe中。
                " </td>"+
                " </tr>"+
                " </table>"+
                "</body>"+
                "</html>";
               //至此,已经定义完contents变量,在后面,我们将看到:它被写入到NBW窗口中去。
 
   pop=window.open("","_blank","fullscreen=yes"); //打开一个全屏窗口。
   pop.resizeTo(w,h); //用resize()方法将窗口定制成自己想要的大小。
   pop.moveTo((screen.width-w)/2,(screen.height-h)/2); //用moveTo()方法将窗口移到屏幕中心。
   pop.document.writeln(contents); //将窗口内容(即变量contents)写进去。
 
   //至此,或许你认为它应该结束了。的确,在IE中,它的确已经结束了,但是在使用了IE内核的多窗口浏览器(比如腾讯的TE)中,一般window.open()是不会弹出新窗口的,而是出现在它的“多窗口”中的一个窗口,所以,后面的代码我们将通过窗口大小来判断NBW窗口是否是独立的窗口,如果不是,我们将使用showModalDialog()对话框做为一个过渡,重新“弹”出一个独立的窗口。
 
   if(pop.document.body.clientWidth!=w||pop.document.body.clientHeight!=h) //通过判断NBW窗口的实际大小来判断NBW是否真正是一个独立的窗口。如果不是,将运行后面的语句。
   {
     temp=window.open("","nbw_v6");
     temp.close(); //上面两句的功能是如果原来有name=nbw_v6的窗口,则将其关闭。
     window.showModalDialog("about:<"+"script language=javascript>window.open('','nbw_v6','fullscreen=yes');window.close();"+"</"+"script>","","dialogWidth:0px;dialogHeight:0px"); //弹出一个对话框,再从对话框中弹出一个name=nbw_v6的全屏窗口,注意这时的窗口肯定是独立的窗口了。
     pop2=window.open("","nbw_v6"); //弹出一个name=nbw_v6的窗口,因为前面弹出过一个name=nbw_v6的全屏窗口,所以这一次的窗口只是在那个窗口中刷新了一下,而通过这样一个过程则把那个窗口赋给了变量pop2。
     pop2.resizeTo(w,h); //用resize()方法将窗口定制成自己想要的大小。
     pop2.moveTo((screen.width-w)/2,(screen.height-h)/2); //用moveTo()方法将窗口移到屏幕中心。
     pop2.document.writeln(contents); //将窗口内容(即变量contents)写进去。
     pop.close(); //将原来没有真正“弹”出来的窗口关掉。
   }
 //*******结束定义noBorderWin()函数******** }
 </script>
 //--------------------------------------------------------------------------------------------------
 
   至此,全部代码讲解完毕。我们可以看到,在实现过程中我们使用了iframe标记,所以现在的NBW窗口仅限在IE及使用IE内核的浏览器中使用

你可能感兴趣的:(.net)