Frage Aktualisieren Sie eine Seite einmal mit jQuery?


Ich frage mich, wie man eine Seite (oder sogar ein bestimmtes div) einmal (!) Mit jQuery aktualisiert / neu lädt?

Idealerweise gleich nach dem DOM structure ist verfügbar (vgl. onload Ereignis) und nicht negativ beeinflussen back button oder bookmark Funktionalität.

Bitte beachten Sie: replace()  ist aufgrund von Beschränkungen durch Dritte nicht erlaubt.


75
2018-04-01 00:47


Ursprung


Antworten:


Okay, ich glaube, ich habe bekommen, wonach du verlangst. Versuche dies

if(window.top==window) {
    // You're not in a frame, so you reload the site.
    window.setTimeout('location.reload()', 3000); //Reloads after three seconds
}
else {
    //You're inside a frame, so you stop reloading.
}

Wenn es einmal ist, dann tu es einfach

$('#div-id').triggerevent(function(){
    $('#div-id').html(newContent);
});

Wenn es regelmäßig ist

function updateDiv(){
    //Get new content through Ajax
    ...
    $('#div-id').html(newContent);
}

setInterval(updateDiv, 5000); // That's five seconds

Daher wird alle fünf Sekunden der Div-ID-Inhalt aktualisiert. Besser als die ganze Seite zu aktualisieren.


78
2018-04-01 00:56



Um es neu zu laden, können Sie Folgendes versuchen:

window.location.reload(true);

66
2018-06-03 08:14



window.location.href=window.location.href;

40
2018-04-01 00:53



$('#div-id').click(function(){

   location.reload();
        });

Dies ist die korrekte Syntax.

$('#div-id').html(newContent); //This doesnt work

4
2018-02-17 11:05



Benutze das:

    <script type="text/javascript">
        $(document).ready(function(){

            // Check if the current URL contains '#'
            if(document.URL.indexOf("#")==-1)
            {
                // Set the URL to whatever it was plus "#".
                url = document.URL+"#";
                location = "#";

                //Reload the page
                 location.reload(true);
            }
        });
    </script>

Aufgrund der if Bedingung wird die Seite nur einmal neu geladen.


4
2018-02-19 08:22



Sie haben keine jQuery-Aktualisierungsfunktion, da dies JavaScript-Grundlagen sind.

Versuche dies:

<body onload="if (location.href.indexOf('reload')==-1) location.replace(location.href+'?reload');">

3
2018-01-22 17:16



Benutzen:

<html>
    <head>
        <title>Reload (Refresh) Page Using Jquery</title>
        <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>
        <script type="text/javascript">
            $(document).ready(function () {
                $('#reload').click(function() {
                    window.location.reload();
                });
            });
        </script>
    </head>
    <body>
        <button id="reload" >Reload (Refresh) Page Using</button>
    </body>
</html>

2
2018-05-20 03:46