在beforeunload期间提交,也许谁从根本上知道另一种方法解决方案

时间:2013-02-05 14:27:02

标签: javascript jquery submit onbeforeunload confirm

在stackoverflow.com上查看了很多类似的问题(也在其他资源上),但没有找到答案。所以我简化和概括了问题。这似乎是一个明显的解决方案:

$(document).ready(function() {
    var a = 3;
    var b = 5;

    // no message when pressed submit button
    $('form').submit(function() {
        $(window).off('beforeunload');
    });

    // confirm of the need to save
    $(window).on('beforeunload', function(e) {
        if (a != b)
            if (confirm('You changed data. Save?')) {
                $('form').submit();
                // alert('Your data is saved. (With alert submit() work only in FireFox!?)');
            }
    });
});

但不要提交工作。如果使用alert(),它仅适用于FireFox。我想纠正(可能没有延迟)跨浏览器解决方案。也许谁知道从根本上另一个方法解决方案。

P.S。关于在第一部分中描述的一些原创性的前载:https://stackoverflow.com/a/6065085/1356425,但这不是明显有效的解决方案。

3 个答案:

答案 0 :(得分:0)

在onbeforeunload-event之后,Chrome和Firefox阻止提交。你必须使用

$(window).on('beforeunload', function(e) {
        if (a != b)
            return 'You\'ve changed the data. Leave page anyway?';
        }                
    });

答案 1 :(得分:0)

我使用同步AJAX(JAX)请求并为各个浏览器运行onUnload或onBeforeUnload事件的处理程序。此解决方案具有单一且几乎跨浏览器的行为。

示例(on jsfiddle):

$(document).ready(function() {

    var form = $('form');
    var textareas = $('textarea');

    function array_compare(a_0, a_1) {
        if(a_0.length != a_1.length)
            return false;

        for(i = 0; i < a_0.length; i++)
            if(a_0[i] != a_1[i])
                return false;

        return true;
    }

    var flag = false; // flag to control the execution of the unloadHandler() once
    var a_open = []; // array with data before unload

    $('textarea').each(function(index) {
        a_open.push($(this).val());
    });

    function unloadHandler() {
        if (flag)
            return;

        var a_close = []; // array with data during unload
        $('textarea').each(function(index) {
            a_close.push($(this).val());
        });

        if (!array_compare(a_open, a_close)) {
            if (confirm('You changed the data, but not saved them. Save?')) {
                $.ajax({
                    type: 'POST',
                    url: '/echo/json/',
                    async: false,
                    data: form.serialize()/* {
                        json: JSON.stringify({
                            text: 'My test text.'
                        }),
                        delay: 3
                    } */,
                    success: function(data) {
                        if (data) {
                            console.log(data);
                            alert('All data is saved!');
                        }
                    }
                });
            }
        }

        flag = true;
    }

    // For FireFox, Chrome
    $(window).on('beforeunload', function () {
        unloadHandler();
    });

    // For Opera, Konqueror
    $(window).unload(function() {
        unloadHandler();
    });

    // Without message when pressed submit button
    $('form').submit(function() {
        $(window).off('beforeunload');
        $(window).off('unload');
    });

});

答案 2 :(得分:0)

在卸载时提交数据的最佳方式是将其存储在localstorage中,并在下次请求同一来源的任何其他页面时发送它。

  function sendBeacon(data) {

    data?dataArr.push(data):'';

    for (var i = 0, len = dataArr.length; i < len; i++) {
        $.getScript(dataArr[i], (function (index) {
            dataArr.splice(index, 1) //Updata dataArray on data submission
        }(i)))
    }
}

$(window).on('beforeunload', function () {
    localStorage.setItem('dataArr', JSON.stringify(dataArr));
})

var dataArr = JSON.parse(localStorage.getItem('dataArr'));

if (!dataArr) {
    dataArr = []; // Create Empty Array
} else {
    sendBeacon(dataArr); //Submit stored data
}