window.open() 打开IE缓慢的原因
2011-01-13 15:02
211 查看
使用window.open()打开子窗口的过程中,同个局域网内的机子,使用IE浏览器,但是打开的速度却不一样.
有的很快,有的却很慢.这肯定对客户体验不好.我们推测是js代码的原因,于是上网查询
网上有的人说不使用第二个参数,即弹出窗口的名字设置为"" 或者"_blank"
照着这实验,没有任何改善.
将window.open() 改成 window.showModalDialog() 打开窗口的速度却很快
最后发现,是IE浏览器本身打开速度的原因. 打开子窗口快的机子,打开IE浏览器速度也快. 而打开子窗
口慢的机子都是打开IE浏览器缓慢.
window.open() 的原理是重新打开一个窗口,(感觉相当于机子重启)
而window.showModalDialog()是在当前父页面上打开一个窗口(感觉就像是机子注销)
从IE下手 工具 -- 管理加载项 -- 把已启用的加载项挨个禁用调试.发现是sun 公司出的java相关的加
载项导致浏览器加载缓慢. 将其禁用之后再测试window.open() 打开速度立马飞升!
<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脚本结束
-----------------------------使用总结-------------------------
模式窗体
var returnval=window.showModalDialog(url,window,"dialogWidth=220px;dialogHeight=530px");
注意第2个参数传递为window作用是可在弹出的窗体中访问父窗口里面的属性或方法,访问形式如下:
dialogArguments.parentfun(){};
returnvalue是一个返回数值,不能是文档对象,而是一个简单的Javascript对象(String,Date...)
window.returnValue="123";那么returnval的数值是123
open弹出的窗体
var obj=window.open
(url,'','location=no,menubar=no,scroll=yes,height=756px,width=940px,resizable=no,status=yes
');
访问父页面方法:如下:
window.opener.parfun(){}
注意obj是对弹出的窗体的一个引用,可以调用obj.close()方法关闭弹出的窗体.
有的很快,有的却很慢.这肯定对客户体验不好.我们推测是js代码的原因,于是上网查询
网上有的人说不使用第二个参数,即弹出窗口的名字设置为"" 或者"_blank"
照着这实验,没有任何改善.
将window.open() 改成 window.showModalDialog() 打开窗口的速度却很快
最后发现,是IE浏览器本身打开速度的原因. 打开子窗口快的机子,打开IE浏览器速度也快. 而打开子窗
口慢的机子都是打开IE浏览器缓慢.
window.open() 的原理是重新打开一个窗口,(感觉相当于机子重启)
而window.showModalDialog()是在当前父页面上打开一个窗口(感觉就像是机子注销)
从IE下手 工具 -- 管理加载项 -- 把已启用的加载项挨个禁用调试.发现是sun 公司出的java相关的加
载项导致浏览器加载缓慢. 将其禁用之后再测试window.open() 打开速度立马飞升!
<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脚本结束
-----------------------------使用总结-------------------------
模式窗体
var returnval=window.showModalDialog(url,window,"dialogWidth=220px;dialogHeight=530px");
注意第2个参数传递为window作用是可在弹出的窗体中访问父窗口里面的属性或方法,访问形式如下:
dialogArguments.parentfun(){};
returnvalue是一个返回数值,不能是文档对象,而是一个简单的Javascript对象(String,Date...)
window.returnValue="123";那么returnval的数值是123
open弹出的窗体
var obj=window.open
(url,'','location=no,menubar=no,scroll=yes,height=756px,width=940px,resizable=no,status=yes
');
访问父页面方法:如下:
window.opener.parfun(){}
注意obj是对弹出的窗体的一个引用,可以调用obj.close()方法关闭弹出的窗体.
相关文章推荐
- window.open()打开的窗口用window.opener()在chrome浏览器下失败的原因
- IE中使用window.open打开新窗口时无法获取Referrer对象
- window.open()打开的新窗口被拦截的原因分析和解决方案
- Ie 8 的window.open打开新窗口无反应问题。
- js window.open('url','_blank') 打开服务器端临时文件, ie窗口一闪而过
- window.open()在IE中打开新窗体有时候打不开的问题
- 解决IE中window.open打开链接refer丢失的问题
- window.open打开的窗体和父窗体之间互传参数
- 一个比window.open() 打开更快的方法
- 刷新父页面(window.open打开的页面)
- window.open 打开子窗口,关闭所有的子窗口
- js关闭 window.open 打开的页面
- javascript:window.open 打开最大化窗口设置及详解
- window.open()新打开窗体的大小及其所有参数
- window.open打开一个居中的窗口
- JavaScript基础 window.open(url,name,options) 在新打开的窗口中写一些文字
- window.open 打开是空白页面
- window.open全屏打开
- window.open打开页面居中显示
- [JavaScript] 解决window.open()打开同一个URL没能在两个网页中打开