我们如何让 htmx 响应触发表单重置?

7 javascript django django-templates htmx

我正在创建一个非常基本的 Django 消息应用程序,并想用它htmx来发送和呈现消息。我可以毫无问题地发布、保存消息并呈现部分消息。但是,我遇到了一个奇怪的问题,我的表单文本区域没有被重置。因此,我会发送一条消息,插入交换后,我的旧消息仍会在文本区域中。这不太理想!

我尝试通过添加 onclick 事件来手动清除文本区域,如下所示:

网页

<div id="new-message-div"></div>


<form id="message-form" class="chat-form rounded-pill bg-dark" data-emoji-form="" hx-post="{% url "chat:create-message" object.pk %}" hx-target="#new-message-div">
...

{{ message_form }}

...

<button class="btn btn-icon btn-primary rounded-circle ms-5" type="submit" onclick="submitForm()"> </button>
</form>
Run Code Online (Sandbox Code Playgroud)

脚本(/sf/answers/1021247601/

<script>
function submitForm() {
   var message_form = document.getElementById('message-form');
   message_form.submit(); // Submit the form
   message_form.reset();  // Reset all form data
   return false; // Prevent page refresh
}
</script>
Run Code Online (Sandbox Code Playgroud)

尽管在submitForm()中有message_form.submit(),我的表单没有被提交,但文本区域正在重置。

问题:

成功发送和渲染消息后,如何重置我的文本区域?

Django 视图,基于https://github.com/legionscript/socialnetwork/blob/84375841429887e394a2a31e1b67919f81a3cb06/social/views.py#L428

def create_message(request, pk):
    message = None

    if request.htmx:
        thread = get_object_or_404(ThreadMessageModel, pk=pk)
        form = MessageModelForm(request.POST)

        if thread.receiver == request.user:
            receiver = thread.user
        else:
            receiver = thread.receiver

        if form.is_valid():
            message = form.save(commit=False)
            message.thread = thread
            message.sender_user = request.user
            message.receiver_user = receiver
            message.save()

        form = MessageModelForm()

        return render(request, 'chat/subtemplate/render_message.html', {'message': message})
Run Code Online (Sandbox Code Playgroud)

Jak*_*her 12

这也有效:

<form hx-put="/" hx-on::after-request="this.reset()">
...
</form>
Run Code Online (Sandbox Code Playgroud)

此处讨论: https: //github.com/bigskysoftware/htmx/pull/1636

  • 为了确保仅在成功后重置表单,需要稍作修改: `hx-on::after-request=" if(event.detail.successful) this.reset()"` (4认同)

Ale*_*dro 2

对于服务器端解决方案,您可以:

  1. 增加目标以hx-target包含新消息和表单,以便在提交时两者都被替换。当然,这种情况下的响应部分需要调整。

  2. 保持现状,但在您对 oob(带外)交换的响应中包含表格https://htmx.org/attributes/hx-swap-oob/。对于 oob 交换,请使用 属性 将表单标记附加到新消息响应中hx-swap-oob="true"