Javascript适用于IE,但不适用于Chrome

时间:2013-08-12 06:06:57

标签: javascript google-chrome cross-browser

我正在尝试通过javascript检测文本,文本区域和下拉列表更改,因此在窗口卸载时,浏览器会提示您有未保存的更改。我的代码与IE完美配合,但它在Chrome中确实不稳定。这是我的代码。

var ctr = 1;
    var isFirstLoad = true;
    function propertyChangedByCode() {
        ctr = 0;
        propertyChanged()
    }
    function propertyChanged() {
        $('[id$=SaveButton]').removeAttr("disabled");
        $('[id$=SaveButton]').removeAttr("class");
        $('[id$=SaveButton]').addClass("btn btn-primary");
        warnMessage = 'Warning: You have unsaved changes.';

        window.onbeforeunload = function () {
            if (ctr == 0) {
                return warnMessage
            }
            else if (ctr == 1) {
                ctr = 0;
            }
        }
    }
    $("body").click(function (event) {
        console.log(event.target);
        if (event.target.type == "submit" && event.target.value != "Save" && event.target.value != "Cancel" && event.target.value != "Next") {
            ctr = 0;
            propertyChanged();
            console.log("BODY clicked");
        }
    });

    function pageLoad() {

        jQuery("input.datepicker").dp({
            dateFormat: 'M d, yy',
            altFormat: 'yy-mm-dd',
            buttonText: '<i class="icon icon-calendar"></i>',
            showOn: 'both'
        });

        $("button.ui-datepicker-trigger").addClass('btn right');

        console.log("PageOnLoad: " + ctr);

        var warnMessage = 'Warning: You have unsaved changes.';
        $('input[type="text"],select,textarea').each(function (k, v) {


            var elem = $(this);
            // Save current value of element
            elem.data('oldVal', elem.val());

            // Look for changes in the value
            elem.bind("change keyup input paste", function (event) {
                // If value has changed...
                if (elem.data('oldVal') != elem.val()) {
                    propertyChanged();
                }
            });
        });

        $('.btn').click(function (e) {
            console.log("whatever");
            ctr = 1;
        });

        //ui-datepicker-trigger
        $('.ui-datepicker-trigger').click(function (e) {
            console.log("date");
            ctr = 0;
        });

        if (isFirstLoad) {
            window.onbeforeunload = null;
            $('[id$=SaveButton]').attr("disabled", "disabled")
            ctr = 1;

            console.log("Disable");
            isFirstLoad = false;
        }
    }

我使用计数器(ctr)并根据具体情况将其更改为1和0。但最终ctr = 0会触发通知,而1则相反。加载页面后,我离开页面,即使我没有任何更改,浏览器也会提示。同样,这段代码在IE中完美运行。我不能使用除此之外的其他解决方案,因为如果我更改当前的程序,我将不得不更新很多页面。有什么想法为什么Chrome不会运行js?谢谢!

修改

在调查代码之后,这一行似乎导致了问题

elem.bind("change keyup input paste", function (event) {
                ctr = 0;
                // If value has changed...
                if (elem.data('oldVal') != elem.val()) {
                    propertyChanged();
                }
            });

if语句在Chrome中首次加载时返回true,而在IE中则返回false。首次加载时哪个应该是假的,因为第一次加载没有变化。

0 个答案:

没有答案
相关问题