Wait cursor over entire html page

95,605

Solution 1

I understand you may not have control over this, but you might instead go for a "masking" div that covers the entire body with a z-index higher than 1. The center part of the div could contain a loading message if you like.

Then, you can set the cursor to wait on the div and don't have to worry about links as they are "under" your masking div. Here's some example CSS for the "masking div":

body { height: 100%; }
div#mask { cursor: wait; z-index: 999; height: 100%; width: 100%; }

Solution 2

If you use this slightly modified version of the CSS you posted from Dorward,

html.wait, html.wait * { cursor: wait !important; }

you can then add some really simple jQuery to work for all ajax calls:

$(document).ready(function () {
    $(document).ajaxStart(function () { $("html").addClass("wait"); });
    $(document).ajaxStop(function () { $("html").removeClass("wait"); });
});

or, for older jQuery versions (before 1.9):

$(document).ready(function () {
    $("html").ajaxStart(function () { $(this).addClass("wait"); });
    $("html").ajaxStop(function () { $(this).removeClass("wait"); });
});

Solution 3

This seems to work in firefox

<style>
*{ cursor: inherit;}
body{ cursor: wait;}
</style>

The * part ensures that the cursor doesn't change when you hover over a link. Although links will still be clickable.

Solution 4

I have been struggling with this problem for hours today. Basically everything was working just fine in FireFox but (of course) not in IE. In IE the wait cursor was showing AFTER the time consuming function was executed.

I finally found the trick on this site: http://www.codingforums.com/archive/index.php/t-37185.html

Code:

//...
document.body.style.cursor = 'wait';
setTimeout(this.SomeLongFunction, 1);

//setTimeout syntax when calling a function with parameters
//setTimeout(function() {MyClass.SomeLongFunction(someParam);}, 1);

//no () after function name this is a function ref not a function call
setTimeout(this.SetDefaultCursor, 1);
...

function SetDefaultCursor() {document.body.style.cursor = 'default';}

function SomeLongFunction(someParam) {...}

My code runs in a JavaScript class hence the this and MyClass (MyClass is a singleton).

I had the same problems when trying to display a div as described on this page. In IE it was showing after the function had been executed. So I guess this trick would solve that problem too.

Thanks a zillion time to glenngv the author of the post. You really made my day!!!

Solution 5

css: .waiting * { cursor: 'wait' }

jQuery: $('body').toggleClass('waiting');

Share:
95,605
Jech
Author by

Jech

Updated on May 22, 2020

Comments

  • Jech
    Jech about 4 years

    Is it possible to set the cursor to 'wait' on the entire html page in a simple way? The idea is to show the user that something is going on while an ajax call is being completed. The code below shows a simplified version of what I tried and also demonstrate the problems I run into:

    1. if an element (#id1) has a cursor style set it will ignore the one set on body (obviously)
    2. some elements have a default cursor style (a) and will not show the wait cursor on hover
    3. the body element has a certain height depending on the content and if the page is short, the cursor will not show below the footer

    The test:

    <html>
        <head>
            <style type="text/css">
                #id1 {
                    background-color: #06f;
                    cursor: pointer;
                }
    
                #id2 {
                    background-color: #f60;
                }
            </style>
        </head>
        <body>
            <div id="id1">cursor: pointer</div>
            <div id="id2">no cursor</div>
            <a href="#" onclick="document.body.style.cursor = 'wait'; return false">Do something</a>
        </body>
    </html>
    

    Later edit...
    It worked in firefox and IE with:

    div#mask { display: none; cursor: wait; z-index: 9999; 
    position: absolute; top: 0; left: 0; height: 100%; 
    width: 100%; background-color: #fff; opacity: 0; filter: alpha(opacity = 0);}
    
    <a href="#" onclick="document.getElementById('mask').style.display = 'block'; return false">
    Do something</a>
    

    The problem with (or feature of) this solution is that it will prevent clicks because of the overlapping div (thanks Kibbee)

    Later later edit...
    A simpler solution from Dorward:

    .wait, .wait * { cursor: wait !important; }
    

    and then

    <a href="#" onclick="document.body.className = 'wait'; return false">Do something</a>
    

    This solution only shows the wait cursor but allows clicks.