0

0

使用 Django 和 HTMX 创建待办事项应用程序 - 创建前端并添加 HTMX 部分

碧海醫心

碧海醫心

发布时间:2025-01-07 16:59:33

|

1209人浏览过

|

来源于php中文网

原创

本系列文章的第三部分带您深入学习如何结合 htmx 和 django 构建动态待办事项列表。如果您错过了前两部分,建议先阅读。

模板和视图的创建

我们将创建一个基础模板和一个指向索引视图的索引模板,该视图列出数据库中的待办事项。我们将使用 DaisyUI(Tailwind CSS 的扩展)来美化界面。

这是添加 htmx 之前的页面截图:

使用 Django 和 HTMX 创建待办事项应用程序 - 创建前端并添加 HTMX 部分

视图和 URL 的添加

首先,更新项目根目录中的 urls.py 文件,以包含我们在“核心”应用程序中定义的 URL:

立即学习前端免费学习笔记(深入)”;

# todomx/urls.py

from django.contrib import admin
from django.urls import include, path

接下来,为应用程序定义新的 URL,创建一个新的文件 core/urls.py

# core/urls.py

from django.urls import path
from . import views

urlpatterns = [
    path("", views.index, name="index"),
    path("tasks/", views.tasks, name="tasks"),
    path("tasks//", views.toggle_todo, name="toggle_todo"),
]

然后创建相应的视图,位于 core/views.py

# core/views.py

from django.shortcuts import redirect, render
from .models import userprofile, todo
from django.contrib.auth.decorators import login_required
from django.views.decorators.http import require_http_methods
from django.http import HttpResponse

def index(request):
    return redirect("tasks/")


def get_user_todos(user: userprofile) -> list[todo]:
    return user.todos.all().order_by("created_at")


@login_required
def tasks(request):
    context = {
        "todos": get_user_todos(request.user),
        "fullname": request.user.get_full_name() or request.user.username,
    }

    return render(request, "tasks.html", context)


@require_http_methods(["PUT"])
@login_required
def toggle_todo(request, task_id):
    todo_item = todo.objects.get(pk=task_id)
    todo_item.completed = not todo_item.completed
    todo_item.save()
    return render(request, "partials/todo-item-partial.html", {"todo": todo_item})

索引路由将重定向到任务视图。任务视图需要登录,并返回用户的全名和待办事项列表。

接下来是模板。我们将为整个应用程序创建一个基础模板,包含 Tailwind CSS 和 DaisyUI,以及任务视图的模板:

{# _base.html #}



    
    
    
    
    
    
    
    {% block header %}
    {% endblock %}


    {% block content %}
    {% endblock %}
    {% block js %}
    {% endblock %}

{# tasks.html #}
{% extends "_base.html" %}
{% load partials %}

{% block content %}

{{ fullname }}'s tasks

    {% for todo in todos %} {% partial todo-item-partial inline todo %} {% endfor %}
{% endblock %}
{# partials/todo-item-partial.html #}
{% load partials %}
  • {{ todo.title }}
  • 我们从 CDN 添加 Tailwind 和 DaisyUI,生产环境应捆绑到应用程序中。我们使用 DaisyUI 5.0 测试版。

    添加内联部分模板

    我们将安装 django-template-partials 插件:

    pip install django-template-partials

    更新 settings.py 文件:

    LALALAND
    LALALAND

    AI驱动的时尚服装设计平台

    下载
    INSTALLED_APPS = [
        # ...
        "template_partials",
        # ...
    ]

    tasks.html 中,我们将每个待办事项定义为内联部分模板。

    使用 htmx 切换待办事项完成状态

    我们将使用 PUT 方法为待办事项实现一个新的 URL 和视图。该视图将返回更新的待办事项的部分模板。

    _base.html 中添加 htmx:

    core/urls.py 中添加新路由: (已在前面添加)

    core/views.py 中添加视图: (已在前面添加)

    现在,您可以测试切换待办事项的完成状态。网络工具将显示 PUT 请求和部分 HTML 响应。

    使用 Django 和 HTMX 创建待办事项应用程序 - 创建前端并添加 HTMX 部分

    使用 Django 和 HTMX 创建待办事项应用程序 - 创建前端并添加 HTMX 部分

    使用 Django 和 HTMX 创建待办事项应用程序 - 创建前端并添加 HTMX 部分

    应用程序已 htmx 化! 下一部分将添加添加和删除任务的功能。

    相关专题

    更多
    css
    css

    css是层叠样式表,用来表现HTML或XML等文件样式的计算机语言,不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

    524

    2023.06.15

    css居中
    css居中

    css居中:1、通过“margin: 0 auto; text-align: center”实现水平居中;2、通过“display:flex”实现水平居中;3、通过“display:table-cell”和“margin-left”实现居中。本专题为大家提供css居中的相关的文章、下载、课程内容,供大家免费下载体验。

    263

    2023.07.27

    css如何插入图片
    css如何插入图片

    cssCSS是层叠样式表(Cascading Style Sheets)的缩写。它是一种用于描述网页或应用程序外观和样式的标记语言。CSS可以控制网页的字体、颜色、布局、大小、背景、边框等方面,使得网页的外观更加美观和易于阅读。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

    754

    2023.07.28

    css超出显示...
    css超出显示...

    在CSS中,当文本内容超出容器的宽度或高度时,可以使用省略号来表示被隐藏的文本内容。本专题为大家提供css超出显示...的相关文章,相关教程,供大家免费体验。

    539

    2023.08.01

    css字体颜色
    css字体颜色

    CSS中,字体颜色可以通过属性color来设置,用于控制文本的前景色,字体颜色在网页设计中起到很重要的作用,具有以下表现作用:1、提升可读性;2、强调重点信息;3、营造氛围和美感;4、用于呈现品牌标识或与品牌形象相符的风格。

    760

    2023.08.10

    什么是css
    什么是css

    CSS是层叠样式表(Cascading Style Sheets)的缩写,是一种用于描述网页(或其他基于 XML 的文档)样式与布局的标记语言,CSS的作用和意义如下:1、分离样式和内容;2、页面加载速度优化;3、实现响应式设计;4、确保整个网站的风格和样式保持统一。

    605

    2023.08.10

    css三角形怎么写
    css三角形怎么写

    CSS可以通过多种方式实现三角形形状,本专题为大家提供css三角形怎么写的相关教程,大家可以免费体验。

    560

    2023.08.21

    css设置文字颜色
    css设置文字颜色

    CSS(层叠样式表)可以用于设置文字颜色,这样做有以下好处和优势:1、增加网页的可视化效果;2、突出显示某些重要的信息或关键字;3、增强品牌识别度;4、提高网页的可访问性;5、引起不同的情感共鸣。

    395

    2023.08.22

    高德地图升级方法汇总
    高德地图升级方法汇总

    本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

    43

    2026.01.16

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    Sass 教程
    Sass 教程

    共14课时 | 0.8万人学习

    Bootstrap 5教程
    Bootstrap 5教程

    共46课时 | 2.9万人学习

    CSS教程
    CSS教程

    共754课时 | 20.2万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号