HTMx-Schaltfläche, die eine POST-Anfrage an die aktuelle Seite anstelle der hx-post-URL sendet [Duplikat]JavaScript

Javascript-Forum
Anonymous
 HTMx-Schaltfläche, die eine POST-Anfrage an die aktuelle Seite anstelle der hx-post-URL sendet [Duplikat]

Post by Anonymous »

Ich erstelle ein Bestätigungsmodal, in dem es über eine Schaltfläche verfügt, die über HTMx eine POST-Anfrage an die mit JavaScript dynamisch festgelegte hx-post-URL senden soll.
Wenn ich auf die Schaltfläche klicke, wird aus irgendeinem Grund eine POST-Anfrage an die aktuelle Seite und nicht an die festgelegte hx-post-URL gesendet.

Hier ist der relevante Code:
Schaltfläche im Liste:

Code: Select all


d="m14.74 9-.346 9m-4.788 0L9.26 9m9.968-3.21c.342.052.682.107 1.022.166m-1.022-.165L18.16 19.673a2.25 2.25 0 0 1-2.244 2.077H8.084a2.25 2.25 0 0 1-2.244-2.077L4.772 5.79m14.456 0a48.108 48.108 0 0 0-3.478-.397m-12 .562c.34-.059.68-.114 1.022-.165m0 0a48.11 48.11 0 0 1 3.478-.397m7.5 0v-.916c0-1.18-.91-2.164-2.09-2.201a51.964 51.964 0 0 0-3.32 0c-1.18.037-2.09 1.022-2.09 2.201v.916m7.5 0a48.667 48.667 0 0 0-7.5 0" />


Eliminar

Bestätigungsmodalität inklusive der Schaltfläche mit dem hx-post:

Code: Select all



✕


¿Estás segura de eliminar este arte?



Cancelar

{% csrf_token %}

Eliminar




close


JavaScript-Snippet, das die hx-post-URL festlegt:

Code: Select all

const delete_btns = document.querySelectorAll("button[data-btn-delete]")
if (delete_btns) {
const mod_confirm_delete = document.getElementById("mod_confirm_delete");
const btn_confirm_delete = document.getElementById("btn_confirm_delete");

delete_btns.forEach((btn) => {
btn.addEventListener("click", (e) => {
const delete_url = btn.dataset.deleteUrl;

btn_confirm_delete.setAttribute("hx-post", delete_url);
btn_confirm_delete.setAttribute("hx-headers", JSON.stringify({
'X-CSRFToken': document.querySelector('[name=csrfmiddlewaretoken]').value
}));

mod_confirm_delete.showModal();

});

});
}

Quick Reply

Change Text Case: 
   
  • Similar Topics
    Replies
    Views
    Last post