Skip to content Skip to sidebar Skip to footer

Jquery - How To Disable The Entire Page

I have this ajax event function save_response_with_ajax(t){ var form = $('#edit_'+t); var div = $('#loading_'+t); $.ajax({ url: form.attr('action'), type: 'POST',

Solution 1:

A way of doing this is having an overlay element which fills the entire page. If the overlay element has a semi-transparent background color, it grays out the page completely: http://jsfiddle.net/SQdP8/1/.

Give it a high z-index so that it's on top of all other elements. That way, it renders correctly, and it catches all events (and won't pass them through).

#overlay {
    background-color: rgba(0, 0, 0, 0.8);
    z-index: 999;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    display: none;
}​

Solution 2:

you can try

 $("body").append('<divid="overlay"style="background-color:grey;position:absolute;top:0;left:0;height:100%;width:100%;z-index:999"></div>');

then just use

$("#overlay").remove();

to get rid of it.

quick & dirty.

Solution 3:

Try appending an overlay during the "beforeSend" function:

$("body").prepend("<div class=\"overlay\"></div>");

$(".overlay").css({
    "position": "absolute", 
    "width": $(document).width(), 
    "height": $(document).height(),
    "z-index": 99999, 
}).fadeTo(0, 0.8);

Solution 4:

This is the complete solution which I am using:

Following are the sections:

  1. CSS for overlay. "fixed" is used to cover whole page content, not just screen height and widths. You can use background color or gif

  2. Attaches to "beforeSend" event of jQuery Ajax call. Creates the overlay on demand and shows it.

  3. Upon completion of request, it removes the overlay from DOM

CSS:

.request-overlay {
    z-index: 9999;
    position: fixed; /*Important to cover the screen in case of scolling content*/left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    display: block;
    text-align: center;
    background: rgba(200,200,200,0.5) url('../../Images/submit-ajax-loader.gif') no-repeat center; /*.gif file or just div with message etc. however you like*/
}

JavaScript:

$.ajax({
                url: '/*your url*/',
                beforeSend: function () {
                    $('body').append('<div id="requestOverlay" class="request-overlay"></div>'); /*Create overlay on demand*/
                    $("#requestOverlay").show();/*Show overlay*/
                },
                success: function (data) {
                    /*actions on success*/
                },
                error: function (jqXhr, textStatus, errorThrown) {
                    /*actions on error*/complete: function () {
                    $("#requestOverlay").remove();/*Remove overlay*/
                }
            });

Solution 5:

Use jQuery ajaxStart() to append a Div to your document. Set it to the size of your document with some form of semi-transparent document. Then remove it on ajaxStop().

Post a Comment for "Jquery - How To Disable The Entire Page"