4

介绍

经过大量试验和错误后,我想使用 HTMX 显示来自 django 后端的消息我最终得到了一个可行的解决方案,我想为任何寻找它的人留下 - 另外,请随时发布您的建议。不幸的是,除了 htmx-django 包中的一个小例子,几乎没有可用的教程材料。请务必查看示例,因为它涵盖了一些专门针对 django 用户的基础知识!

4

1 回答 1

2

解决方案

对于 HTMX,我们需要在 DOM 中的某个地方有一个 HTMX 可以工作(例如交换)的小元素。例如放置一个

<div id="msg">
    {% include "app/messages-partial.html" %} 
</div> 

在你的某个地方index.html。现在我们想使用这个元素来填充它,如果需要的话。假设我们单击一个按钮,该按钮与视图通信并发布答案。在 django 中,响应是使用以下命令创建的render

class TestView(TemplateView):
    template_name = "index.html"
    
    def get(self, request, *args, **kwargs):
        ...
        class_code = """class='alert alert-dismissible fade show'"""
        msg_str = """testmessage"""
        msg_btn = """<button type='button' class='close' data-dismiss='alert'>x</button>"""
        msg = mark_safe(f"""<div {classcode}>{msg_str}{msg_btn}</div>""")
        return render(request, "app/messages-partial.html", {"msg": msg})

和对应pathurls.py

path("action/", views.TestView.as_view(), name = "test"),

我创建了一个简单的messages-partial.html

{% if msg %}
    {{ msg }}
{% endif %}

所以我想要的是,当我触发视图时,{{ msg }}HTMX 将其替换(交换)为响应的内容。因此,我在其他地方实现了 HTMX 部分index.html,如下所示:

<div class="..."
     hx-get="/action"
     hx-swap="innerHTML"
     hx-target="#msg" >
         <button class="btn btn-primary">TEST</button>
</div>

前者将与(我包括典型的关闭按钮)<div id="msg">...</div>交换。{{ msg }}django-messages

感谢 htmx discord 频道,友好的人们与我分享了他们的知识。

于 2021-05-03T07:00:32.597 回答