简体   繁体   中英

window.opener alternatives

I am opening a modal popup window. Then I access a parent window textbox and other attributes using window.opener . It is working fine in firefox but not in IE8. It gives error 'window.opener is null' . How can I access parent window attributes in child window which works in both browsers.

There are two ways to solve the problem: Note: " window.opener " is not supported by IE if " showModalDialog " is been used.

1) Instead of " window.showModalDialog " use " window.open "

2) If you want to use " window.showModalDialog " then do the following:

<script language="javascript" type="text/javascript">
    function YourFunction()
    {
        var opener = null;

        if (window.dialogArguments) // Internet Explorer supports window.dialogArguments
        { 
            opener = window.dialogArguments;
        } 
        else // Firefox, Safari, Google Chrome and Opera supports window.opener
        {        
            if (window.opener) 
            {
                opener = window.opener;
            }
        }       
        // write you code and refer "opener"
        window.close();
    }
</script>

You can pass arguments to showModalDialog function. Simply pass window object as an argument.

window.showModalDialog(theURL, window);

Yo can access the arguments from the modal window using dialogArguments. See: http://msdn.microsoft.com/en-us/library/ms533723%28VS.85%29.aspx

var openerWindow = window.dialogArguments;

Disable Internet Explorer's "Protected Mode", which prevents access to this object.

The steps for this are:

  1. Press Alt+T to show the Tools menu
  2. Click "Internet options"
  3. Select the "Security" tab
  4. Make sure zone selected contains your site. For an intranet site it would typically be "Local intranet" zone.
  5. Untick "Enable Protected Mode"
  6. Close all IE tabs and windows and re-open.

Now you should be able to access the window.opener object.

The approach I would take is the following:

  1. Use an existing JavaScript UI library because you are not the first person to ever want to do this, failing that
  2. Create a function called OpenWindow , that browser sniffs for the window.opener method

For example:

if(window.opener == undefined) {
   //probably not Firefox...
}

and if it finds it then uses it, else it tests for the IE variant and uses it. And then it checks Safari's version, etc...

As a cross-browser alternative, you can give a custom attribute to the new window while you are opening it:

var popup = window.open(...);
popup.isPopup = true;

Then, in the referred page:

if (window.isPopup) {
  // Do something
}
else {
  // Not in a popup
}

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM