2016-04-29 10 views
0

ポップアップウィンドウがあり、リフレッシュするとunbeforeunloadコールバックが失われます。 unbeforeunloadメソッドをリフレッシュされたポップアップウィンドウにバインドする正しい方法は何ですか?更新されたポップアップウィンドウに再度unbeforeunloadメソッドをバインドします。

var url = ..., 
    title = ..., 
    params = [ 
    "height=" + screen.height, 
    "width=" + screen.width, 
    "fullscreen=yes", 
    "resizable=yes", 
    "scrollbars=yes", 
    "toolbar=yes", 
    "menubar=yes", 
    "location=yes" 
    ].join(","); 

    var popup = window.open(url, title, params), 
     onbeforeunloadCallback = function (e) { 
        var isRefresh = this.opener.title == undefined; 

        if (isRefresh) { 
        // It doesn't work for second refresh 
        // so what am I doing wrong ? 
        console.log("It is refreshing"); 

        popup.onbeforeunload = onbeforeunloadCallback; 
        } 
     }; 

popup.onbeforeunload = onbeforeunloadCallback; 

答えて

0

最後に、以下のコードが私の問題を解決しました。以下の関数はajax呼び出しの成功の中にあるので、data.ParametersGuidはajaxから返された値です。また、この値を使用して、複数のポップアップを次のコードに示すように区別します。

var url = ..., 
    title = ..., 
    params = [ 
    "height=" + screen.height, 
    "width=" + screen.width, 
    "fullscreen=yes", 
    "resizable=yes", 
    "scrollbars=yes", 
    "toolbar=yes", 
    "menubar=yes", 
    "location=yes" 
    ].join(","); 

var isRefresh = false, 
popup = window.open(options.url, options.title, params), 
getCurrentPopup = function() { 
    var possibleCurrentPopupHandler = $.grep(window.popups, function (o) { return o.id === data.ParametersGuid }), 
     currentPopup = possibleCurrentPopupHandler.length > 0 ? possibleCurrentPopupHandler[0].popup : null; 

    return currentPopup; 
}, 
setPopupCallbacks = function (p) { 
    p = p != null ? p : getCurrentPopup(); 

    if (p == null) return; 

    console.log("setPopupCallbacks -----"); 

    p.onload = onloadCallback; 
    p.onbeforeunload = onbeforeunloadCallback; 
    p.onunload = onunloadCallback; 
    p.onkeydown = onkeydownCallback; 
}, 
onloadCallback = function (e) { 
    console.log("I'm in onloadCallback func"); 

    setPopupCallbacks(); 
}, 
onbeforeunloadCallback = function (e) { 
    if (isRefresh) { 
     console.log("I'm refreshed in onbeforeunloadCallback func"); 

     isRefresh = false; 
     setPopupCallbacks(); 
    } else { // popup is being closed 
     console.log("I'm about to close in onbeforeunloadCallback func"); 

     window.popups = $.grep(window.popups, function (o) { return o.id !== data.ParametersGuid }); 
     element.clientModel.deleteSessionParameters(data.ParametersGuid); 
    } 
}, 
onunloadCallback = function (e) { 
    console.log("I'm in onunloadCallback func"); 

    setTimeout(function() { setPopupCallbacks(); }, 500); 
}, 
onkeydownCallback = function (e) {  
    var ctrlRClick = e.keyCode == 65 && e.ctrlKey, 
     f5Click = (e.which || e.keyCode) == 116; 

    isRefresh = ctrlRClick || f5Click; 
}; 

setPopupCallbacks(popup); 

window.popups = window.popups || []; 
window.popups.push({ 
    id: data.ParametersGuid, 
    popup: popup 
}); 
関連する問題