解决window.showModalDialog在Firefox无法支持

本文介绍了一种在父窗口与子窗口间传递颜色选择结果的方法。通过使用JavaScript的showModalDialog(IE)和window.open,实现了从子窗口将颜色值返回到父窗口的功能。此方法适用于需要在不同窗口间交互的场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

None.gif<script language="javascript">
ExpandedBlockStart.gifContractedBlock.gif
function colorpick(obj)dot.gif{
InBlock.gif   
if (window.showModalDialog!=null)//IE判断
ExpandedSubBlockStart.gifContractedSubBlock.gif
   dot.gif{
InBlock.gif      
var smd= window.showModalDialog("Default2.aspx","","dialogWidth:225px;dialogHeight:170px;status:no;help:no;scrolling=no;scrollbars=no");
InBlock.gif   
if(smd!=null)
InBlock.gif  obj.style.background
=rtn;
InBlock.gif  
return;
ExpandedSubBlockEnd.gif   }

InBlock.gif   
else
ExpandedSubBlockStart.gifContractedSubBlock.gif   
dot.gif{
ExpandedSubBlockStart.gifContractedSubBlock.gif    
this.returnAction=function(strResult)dot.gif{
InBlock.gif    
if(strResult!=null)
InBlock.gif    obj.style.background
=strResult;
ExpandedSubBlockEnd.gif    }

InBlock.gif     window.open(
"Default2.aspx","","width=225,height=170,menubar=no,toolbar=no,location=no,scrollbars=no,status=no,modal=yes");
InBlock.gif    
return;
ExpandedSubBlockEnd.gif  }

InBlock.gif 
ExpandedBlockEnd.gif   }

None.gif
</script>
None.gif

在一个父窗口中打开一个子窗口,并把子窗口的值传递给父窗口

在父窗口中:

 在子窗口中:

ExpandedBlockStart.gifContractedBlock.giffunction act(RGB) dot.gif{
InBlock.gif  
if (window.showModalDialog!=null)//IE判断
ExpandedSubBlockStart.gifContractedSubBlock.gif
 dot.gif{
InBlock.gif parent.window.returnValue
="#"+RGB;
InBlock.gif window.close();
//firefox不支持
InBlock.gif

ExpandedSubBlockEnd.gif}

InBlock.gif 
else
ExpandedSubBlockStart.gifContractedSubBlock.gif 
dot.gif{
InBlock.gif window.opener.returnAction(
"#"+RGB);
InBlock.gif top.close();
//IE和FireFox都支持
ExpandedSubBlockEnd.gif
 }

ExpandedBlockEnd.gif}

None.gif

转载于:https://www.cnblogs.com/kangtr/archive/2008/07/03/1234404.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值