Als ik mijn contactformulier invul en verstuur wordt ik doorgestuurd naar een bedankpagina.
Echter, als ik op de terug knop in mijn browser druk komt het ingevulde formulier weer te voorschijn. Dat wil ik niet.
Dus heb ik onderstaande snippet gevonden en toegevoegd. Dit zorgt ervoor dat de vorige pagina herladen wordt als ik op de terug knop druk. Waardoor formulier dus leeg getoond wordt.
if (window.performance.getEntriesByType('navigation')[0].type === "back_forward") {location.reload();}
Ik heb weinig verstand van JS, mijn vraag is of dit correct is en geen deprecated onderdelen bevat?
Ik las dat "navigation" deprecated is, maar ik weet niet of dit over het element uit mijn code gaat: https://developer.mozilla.org/en-US/docs/Web/API/Performance
@arien - dat zal betekenen dat ik mijn hele plugin moet ombouwen, omdat die gebruikt maakt van $_post methode.
@Adoptive Solution - Bedankt, maar het betreft een plugin van WordPress en het gebruik van PHP sessies wordt sterk ontmoedigd (WordPress heeft een zogenaamnde transients API voor tijdelijke opslag van data).
Ik heb nog geen oordeel gekregen over mijn JS fix?
Dit werkt ook, lijkt een betere browser support te hebben:
if (window.performance.getEntriesByType('navigation')[0].type === "back_forward") {window.location.href=window.location.href;}
[size=xsmall]Toevoeging op 24/09/2023 23:27:45:[/size]
Los het serverside op. Clientside kan je alles omzeilen.
Deze methode gebruik ik al voor doorsturen na succesvol verzenden. Dus verversen vd pagina is ondervangen, alleen mijn vraag ging over terug naar vorige pagina.
Ik maak dus al gebruik van Post/Redirect/Get en dat werkt prima. Ik zie dat mijn $_post global leeg is na verzenden van formulier.
De reden waarom formulier ingevuld is als ik op de terug knop druk komt doordat de waardes in geheugen van de browser blijven staan.. Is dat op een eenvoudige manier op te lossen? Ik kan autocomplete="off" toevoegen aan mijn formulier maar dat werkt niet optimaal in alle browsers merk ik.
Aanvulling: ik ben er achter dat dit met headers / de back/forward cache te maken heeft.
Aanvulling: ik ben er achter dat dit met headers / de back/forward cache te maken heeft.
Als ik formulier verstuur, word ik doorgestuurd naar een bedankpagina. Echter, als ik dan op de terug knop in mijn browser druk verschijnt de vorige pagina weer in beeld met daarop het ingevulde(!) formulier. Dat voorkom ik met onderstaande code (bron (oa) Stack Overflow). De pagina wordt herladen, met als gevolg dat formulier leeg gemaakt wordt.
if (document.addEventListener) {
window.addEventListener('pageshow', function (event) {
if (event.persisted || performance.getEntriesByType("navigation")[0].type === 'back_forward') {
location.reload();
}
},
false);
}
En zie mijn toenmalige reactie, gebruik van PHP sessie wordt afgeraden binnen het betreffende CMS (WordPress).
Waar heb je dat gevonden? Ik ben benieuwd hoe dat bekrachtigd wordt en wat de argumenten zijn, want ik zie diverse tutorials over Wordpress plug-ins die gewoon PHP sessies gebruiken.