最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - how to close a popup window when the focus is gone out from it - Stack Overflow

programmeradmin2浏览0评论

Requirement: A popup will be opened up from parent window, and it should get closed when the focus from the window is lost. (This should happen even when another application window is opened or came into focus).

Tried code: <body onBlur='javascript:window.close();'>

Issue: On click within the body of the popup makes the popup closed.

Compatibility: ie6 and above, firefox.

I got a workaround from .html

var active_element;  
var bIsMSIE;

function initiateSelfClosing() {  
  if (navigator.appName == "Microsoft Internet Explorer") {  
    active_element = document.activeElement;  
    document.onfocusout = closeWnd;  
    bIsMSIE = true;  
  }  
  else { window.onblur = closeWnd; }  
}

function closeWnd() {  
  if (window.opener != null) {  
    if (bIsMSIE && (active_element != document.activeElement)) {  
      active_element = document.activeElement;  
    }  
    else {  
      window.close();  
    }  
  }  
}  


<body onload="initiateSelfClosing()">  
</body>

But here also one problem is there, if there is a print button in the page, and if am clicking on print > then cancelling the print job, the popup is getting closed.

Can some one help me pls...

Requirement: A popup will be opened up from parent window, and it should get closed when the focus from the window is lost. (This should happen even when another application window is opened or came into focus).

Tried code: <body onBlur='javascript:window.close();'>

Issue: On click within the body of the popup makes the popup closed.

Compatibility: ie6 and above, firefox.

I got a workaround from http://pro-thoughts.blogspot./2006/10/incorrect-behavior-of-windowonblur.html

var active_element;  
var bIsMSIE;

function initiateSelfClosing() {  
  if (navigator.appName == "Microsoft Internet Explorer") {  
    active_element = document.activeElement;  
    document.onfocusout = closeWnd;  
    bIsMSIE = true;  
  }  
  else { window.onblur = closeWnd; }  
}

function closeWnd() {  
  if (window.opener != null) {  
    if (bIsMSIE && (active_element != document.activeElement)) {  
      active_element = document.activeElement;  
    }  
    else {  
      window.close();  
    }  
  }  
}  


<body onload="initiateSelfClosing()">  
</body>

But here also one problem is there, if there is a print button in the page, and if am clicking on print > then cancelling the print job, the popup is getting closed.

Can some one help me pls...

Share Improve this question edited Jan 26, 2012 at 10:51 jijo thomas asked Jan 25, 2012 at 11:02 jijo thomasjijo thomas 3472 gold badges5 silver badges13 bronze badges 0
Add a ment  | 

3 Answers 3

Reset to default 2

Little corrections in sathishkumar's answer

1.we need to convert win to jquery object

2.Apply blur event on jqvariable and not on window

3.this.close is good enough in definition of onblur event

 var win = window.open("URL");
 var jqwin = $(win);
  $(jqwin).blur(function() {
    this.close();
 });

Use document for blur event

  var win = window.open("URL");
  $(window).blur(function() {
    win.close();
  });

You cannot attach onblur event to BODY but
you Can attach a function on Onblur event of window.

<script type="text/javascript">
    function closeme()
    {  
        window.close();
    }
    window.onblur=closeme;
</script>

Since you have Edited your Question, You can get more help here

发布评论

评论列表(0)

  1. 暂无评论