JavaScript-Funktion zum Cookie-Editieren funktioniert in WordPress nicht

Wie ich bereits in meinem vorherigen Artikel gezeigt habe, gibt es ein paar unschöne Probleme wenn man versuchen möchte aus einem Artikel in WordPress eine JavaScript-Funktion per Link aufzurufen. Dies ließ sich zwar grundsätzlich lösen, funktionierte aber für meine spezielle Funktion immer noch nicht. Falls also noch jemand eine JavaScript-Funktion nutzt, die ein Cookie löscht bzw. dessen Wert verändert, folgt in diesem Artikel der Workaround eines Workarounds…

Problem

Aus irgendeinem Grund funktioniert eine Änderung eines Cookies nicht mit der „document.cookie“-Funktion in meinem Javascript-Code, wenn ich diesen wie in dem anderen Artikel einbaue. Stattdessen habe ich den entsprechenden Part mit den Links und die genutzten JavaScript-Funktionen einfach in eine eigene von WordPress losgelöste html-Datei ausgelagert. Wenn ich diese aus der HTML-Datei ausführe gibt es nichts zu beanstanden.

 

Lösung

Meine erste Idee war es dann einfach die zum Testen erstellte HTML-Datei zu behalten und diese aufzurufen. Innerhalb dieser kann ja auch ohne Interaktion des Benutzers der entsprechende JavaScript-Code direkt ausgeführt werden. An sich funktionierte das auch. Es gab nur leider ein weiteres unschönes Problem. Da so eine weitere geöffnete Seite ja unschön ist und nicht vom Benutzer zu schließen sein sollte, wollte ich dies einfach ebenfalls durch JavaScript direkt im Anschluss an die Ausführung meiner Funktion erledigen lassen. Leider stellte ich nach erfolglosem Herumprobieren und etwas Recherche dann fest, dass mit JavaScript’s „Window.Cloase“ leider nur bereits per JavaScript geöffnete Fenster wieder geschlossen werden können.

Dies kann man auch hier nachlesen: https://medium.com/javascript-in-plain-english/closing-a-window-with-javascript-beeec56344bb

Somit wäre hier wahrscheinlich noch eine JavaScript-Funktion, die man in WordPress aufruft nötig, die das neue Fenster öffnet. Das ist mir aber zu dämlich und wirklich weit am Ziel vorbei geschossen.

 

Ich habe letzt endlich einfach die HTML-Datei behalten und old-school-mäßig per „IFrame“ in meiner WordPress-Seite wieder eingebunden:

 

Das Ergebnis könnte dann z.B. so aussehen:

Dies sieht so zwar nicht schön aus, weil ich keinen Bock mehr hatte die CSS-Regeln für diese Html-Datei zu pflegen, aber da es sowieso nur für die Datenschutzerklärung ist: who cares… Es wurde eh schon zu viel Zeit dafür verschleudert.

 

Fazit

Ein weiterer wirklich unschöner Workaround für eine eigentlich einfache Sache, der viel Zeit und Nerven verschwendet hat.

 

Tobias Langner

Tobias Langner

Ich arbeite seit mehreren Jahren als Software-Release-Manager, zuvor als IT-Administrator, bin ausgebildeter Fachinformatiker für Systemintegration und Studium-"Pausierer" an der FernUni Hagen. Achtung: Für die Richtigkeit der zur Verfügung gestellten Informationen, Skripte, etc. übernehme ich keine Gewähr. Deren Nutzung geschieht ausdrücklich auf eigene Gefahr!

Alle Beiträge ansehen von Tobias Langner →

Schreibe einen Kommentar

Deine E-Mail-Adresse wird nicht veröffentlicht. Erforderliche Felder sind mit * markiert