使用 Django 和 HTMX 创建待办事项应用程序 – 添加新待办事项的部分

在本教程的第三部分,我们实现了待办事项的添加和删除功能。接下来,我们将添加一个表单,用于创建新的待办事项,并利用 htmx 和后端路由处理 post 请求。

表单效果如下:

使用 Django 和 HTMX 创建待办事项应用程序 - 添加新待办事项的部分

处理 POST 请求

创建新待办事项,通常有两种 POST 路由方法:使用单独的路由(例如 /tasks/create)或复用已有的任务列表路由 /tasks。我们选择后者,因为它更符合 RESTful 和超媒体原则,但两种方法都可行。

由于 URL 已定义,我们只需修改 core/views.py 中的任务视图。为了代码简洁,我们将 POST 请求处理代码放在单独的函数中。

def _create_todo(request):  # ...

templates/tasks.html 中,我们添加一个新的表单:

{% extends "_base.html" %}{% load partials %}{% block content %}

{{ fullname }}'s tasks

    {% for todo in todos %} {% partialdef todo-item-partial inline %}
  • {{ todo.title }}
  • {% endpartialdef %} {% endfor %}
{% endblock %}

表单的关键代码在于:

hx-post="{% url 'tasks' %}":表单将发送 POST 请求到 /tasks URL。hx-swap="beforeend"hx-target="#todo-items":将响应插入到 #todo-items 元素(ul 列表)的末尾。如果要添加到顶部,可以使用 afterbeginhx-on:after-request="this.reset()":请求完成后重置表单,方便连续添加任务。

效果演示:

使用 Django 和 HTMX 创建待办事项应用程序 - 添加新待办事项的部分

处理缓慢的请求

为了提升用户体验,我们需要处理网络延迟问题。 在 tasks.html 中,我们为提交按钮添加 hx-disable-elt 属性:

对于切换待办事项完成状态的复选框,我们在请求期间使用 hx-on:click 禁用它:


模拟缓慢网络请求后效果:

使用 Django 和 HTMX 创建待办事项应用程序 - 添加新待办事项的部分

模拟缓慢网络请求后的动画演示:

使用 Django 和 HTMX 创建待办事项应用程序 - 添加新待办事项的部分

至此,我们完成了待办事项创建功能的开发。在第五部分,我们将添加视图层测试。 代码已提交到 GitHub 分支。

以上就是使用 Django 和 HTMX 创建待办事项应用程序 – 添加新待办事项的部分的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1355268.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月13日 19:08:26
下一篇 2025年12月13日 19:08:39

相关推荐

  • 函数、变量和调试;重新开始我的 DS、AI 和 ML 之旅

    探索python编程的奇妙旅程:深入理解函数与全局变量 一直以来,构建优秀程序的挑战激发着我的热情。虽然我秉持着谦逊的学习态度,但此刻,我渴望将所学知识用于更广阔的应用,造福大众。 近日,我深入复习了Python的基础概念,并从中获得了重要的领悟: 更深层次的思考 我开始追问更深层次的问题,例如:“…

    好文分享 2025年12月13日
    000
  • 使用 Beautiful Soup 和 Scrapy 进行网页抓取:高效、负责任地提取数据

    在信息时代,网络数据至关重要。网页抓取技术成为获取在线信息的重要手段。本文将对比分析两个流行的Python网页抓取库:Beautiful Soup和Scrapy,提供代码示例并阐述负责任的抓取实践。 网页数据提取概述 网页数据提取是自动从网站获取数据的过程,广泛应用于数据分析、机器学习和市场调研等领…

    2025年12月13日
    000
  • CS-第 6 周

    Python 编程入门:简洁高效的代码 Python 作为一门易于学习和应用的编程语言,深受初学者和专业人士的喜爱。不同于 C 语言的编译型特性,Python 是一种解释型语言,代码无需单独编译即可在 Python 解释器中直接运行。 例如,经典的 “Hello, world!&#822…

    2025年12月13日
    000
  • 构建 Python 相机 SDK 并使用它进行多条码扫描

    现在,轻量级 c 相机 sdk 已针对 windows、linux 和 macos 完成,我们可以将其集成到其他高级编程语言中。在本文中,我们将探讨如何基于 c 相机库构建 python 相机 sdk,并使用它与 dynamsoft barcode reader sdk 进行多条码扫描。 pytho…

    2025年12月13日
    000
  • 全部在 PyTorch 中

    pytorch 的 torch.all() 函数详解及示例 本文将详细解释 PyTorch 中 torch.all() 函数的功能、参数以及使用方法,并提供丰富的代码示例进行说明。 torch.all() 用于检查张量中所有元素是否都为真 (True)。 函数功能: torch.all() 函数用于…

    2025年12月13日
    000
  • Python Day-Dictionary-练习、任务

    字典 – {}: 字典存储键值对数据,有序、可变且键值唯一。 练习: 字典的基本操作: menu = {‘idli’: 10, ‘dosai’: 20, ‘poori’: 30}print(menu) # 输出:{‘idli’: 10, ‘dosai’: 20, ‘poori’: 30}…

    2025年12月13日
    000
  • 初学者大 O 表示法:实用指南

    代码运行速度差异巨大,原因何在?答案是:大O表示法——程序员评估算法效率的利器。本文将简明扼要地解释大O表示法。 什么是大O表示法? 大O表示法描述算法性能随输入规模增长变化的趋势。它衡量的是,当输入数据量增加时,算法执行时间如何变化。 常见的大O复杂度 O(1) – 常数时间 最佳性能…

    2025年12月13日
    000
  • 学习如何编码?

    您是否好奇网站、应用和游戏的幕后奥秘?答案就在于编码!编码是计算机能够理解的语言,如同我们用英语或其他语言交流一样,计算机也需要特殊的语言来执行指令。如果您渴望学习编码,那么您已经找到了正确的资源! 本文将引导您如何通过简单易懂的步骤,免费学习Python和JavaScript编程。这两种语言功能强…

    2025年12月13日
    000
  • PyTorch 中的正方形

    请我喝杯咖啡☕ 本文将介绍 PyTorch 中的 square() 函数,该函数用于计算张量中每个元素的平方。 square() 函数详解 square() 函数可以对 0 维或多维张量中的每个元素进行平方运算。其使用方法灵活,既可以直接作用于张量对象,也可以作为 torch 模块中的一个函数使用。…

    2025年12月13日
    000
  • 介绍 acolor:打印 ANSI 颜色代码的小实用程序

    之前我分享过一个想法,想创建一个工具来方便地将 ANSI 颜色代码输出到控制台。 因为我正在改进我的 shell 提示符,所以觉得开发这个工具比不断搜索 shell 代码更高效。 于是,我创建了 acolor,一个基于 colorist 库的开源 Python 实用程序。它提供了一种简单的方法来生成…

    2025年12月13日
    000
  • PyTorch 中的余数

    pytorch 的 remainder() 函数详解:高效进行模运算 本文将详细介绍 PyTorch 中 remainder() 函数的用法,它可以对张量或标量进行高效的模运算(求余数)。 一杯咖啡☕已备好,请享用! remainder() 函数能够对两个张量或一个张量和一个标量进行逐元素的模运算,…

    2025年12月13日
    000
  • 使用 ML 预测笔记本电脑价格

    本文介绍了一个使用python从pccomponentes网站抓取数据,并构建机器学习模型预测笔记本电脑价格的项目。该项目解决了现有公共数据集数据过旧的问题,通过直接抓取网站数据获得更可靠、更新的数据。 项目首先使用numpy、pandas和matplotlib库处理抓取到的数据,并删除包含空值的行…

    2025年12月13日 好文分享
    000
  • 日清单理解

    列表推导式: 列表推导式是一种简洁优雅的Python语法,允许在一行代码中创建或修改列表。 示例1:打印包含字母“a”的水果(使用for循环): fruits = [“apple”, “banana”, “cherry”, “kiwi”, “mango”]newlist = []for x in f…

    2025年12月13日
    000
  • 我有时使用 awk 而不是 Python 的四个原因

    Python 是一门强大的编程语言,但在某些特定场景下,Awk 的优势更为显著,尤其体现在可移植性、生命周期、代码简洁性和与其他工具的互操作性方面。 Python 脚本通常具有良好的可移植性,但并非总能在所有环境中完美运行,例如流行的 Docker 基础镜像 (如 Debian 和 Alpine)。…

    2025年12月13日
    000
  • 如果缺少设置,请自行添加

    我玩《everspace 2》有一段时间了,这款由rockfish games开发发行的动作冒险太空射击游戏让我爱不释手!在浩瀚的星系中驾驶飞船探险,体验感很棒。 然而,游戏中一些显示元素的设计让我略感困惑。特别是游戏中的标记系统,用于在HUD上显示兴趣点。 当视线无阻碍时,标记显示为白色;如有物体…

    2025年12月13日
    000
  • 日 – 列表功能

    Python 列表提供了丰富的操作方法,本文将重点介绍 extend()、append()、insert()、reverse()、sort() 和 sorted() 等方法,并结合示例讲解其用法。此外,还将演示如何查找列表中的最小值、最大值、第二小值和第二大值,以及 in 和 not in 运算符的…

    2025年12月13日
    000
  • 日常词典和任务

    字典: 字典是一种内置的数据结构,以键值对的形式存储数据。它是有序的、可变的、不允许键重复的集合。字典用花括号 {} 表示。 示例代码: menu = {‘idli’: 10, ‘dosai’: 20, ‘poori’: 30}print(menu) # 输出: {‘idli’: 10, ‘dosa…

    2025年12月13日
    000
  • 了解 OpenAI JSONL 格式:组织记录

    早期邮政分拣系统面临的挑战,与如今使用大型语言模型 (LLM) 类似。 如同早期邮局因处理邮件数量不足而导致信件退回,不正确的输入格式也会导致 LLM 微调失败或效果不佳。OpenAI 使用 JSONL (JSON Lines) 格式作为微调数据的标准,确保数据结构化并易于处理。 JSONL 格式的…

    2025年12月13日
    000
  • 天元组,集合

    元组:Python 中有序、不可变的数据结构 元组是 Python 中一种内置的数据结构,它以固定顺序存储多个项目。 一旦创建,元组的内容就不能更改。与列表类似,元组可以包含重复的值和混合数据类型(其他元组、列表、数字、字符串等)。 元组的元素可以通过索引访问,索引从 0 开始。元组用圆括号 () …

    2025年12月13日
    000
  • 在 PyTorch 中排列

    pytorch 的 torch.arange() 函数详解:创建数值序列张量 本文将详细介绍 PyTorch 中 torch.arange() 函数的功能、参数以及使用方法,并辅以代码示例。torch.arange() 函数用于创建包含指定范围内的数值序列的张量。 函数签名: torch.arang…

    2025年12月13日
    000

发表回复

登录后才能评论
关注微信