現在我們已經在第 3 部分新增了開啟和關閉待辦事項項目的功能,讓我們新增一個表單來建立新的待辦事項項目,使用 HTMX 和接受 POST 請求的路由。
它看起來像這樣:
擴展視圖以接受 POST 請求
要建立新帖子,我們有兩種常見的 POST 路由選項:一種是使用單獨的路由,例如 /tasks/create,另一種是使用我們已經列出任務的相同路由, /任務。我們會選擇後者,因為它最符合 REST 和超媒體實踐,但兩者都很好。
由於 URL 已經定義,我們只需要更改 core/views.py 中的任務視圖。為了保持程式碼簡潔,我們將在單獨的函數上保留處理 POST 請求的程式碼。
def _create_todo(request): # <p>在 templates/tasks.html 上我們將新增一個表單<br> </p> <pre class="brush:php;toolbar:false"><!-- core/templates/tasks.html --> {% 擴充“_base.html” %} {% 載入部分 %} {% 區塊內容 %} <div> <p>所有有趣的程式碼都在表單標籤:</p> <ul> <li> hx-post="{% url 'tasks' %}" 表示表單將向任務 url 發出 POST 請求;</li> <li> hx-swap="beforeend" 和 hx-target="#todo-items" 一起工作;它將回應的目標設定為 #todo-items 標記(ul),並且應該在清單末尾之前新增片段。如果我們想在頂部新增項目,我們可以使用 afterbegin 來代替。 </li> <li> hx-on::after-request="this.reset()" 將在請求發送後重置表單(清理輸入文字);這將允許我們透過鍵入並按「Enter」鍵提交表單來一次新增多個任務。 </li> </ul> <p>讓我們來看看它的實際效果吧! </p> <p><img src="/static/imghwm/default1.png" data-src="https://img.php.cn/upload/article/000/000/000/173595748091013.jpg?x-oss-process=image/resize,p_40" class="lazy" alt="Creating a To-Do app with Django and HTMX - Part adding new Todos"></p> <h2> 處理緩慢的請求 </h2> <p>現在我們可以新增項目了,讓我們處理一個常見的使用者體驗問題:延遲。雖然我們在本地主機上的測試非常快,但在現實世界中,創建和切換待辦事項的請求可能需要一兩秒,並且用戶可能不確定發生了什麼。 </p> <p>對於提交按鈕,我們將使用 hx-disable-elt 屬性,並將其設定為tasks.html`</p>中的提交按鈕 <p>金賈<br> </p> <form hx-post="{% url 'tasks' %}"> hx-swap="beforeend" <br> hx-target="#todo-items" <br> hx-on::after-request="this.reset();"<br> hx-disabled-elt="#submit" <!-- 新 --><br> > <input type="text" required name="title" placeholder="新增待辦事項" class="input input-bordered flex-1 text-lg"><br> 表格><br> <p>對於切換功能,我們可以在請求期間使用 hx-on:click 停用複選框</p> <p>`金賈</p> <pre class="brush:php;toolbar:false">
`
我們可以透過開啟開發者工具/網路並將 Throttling 選項設為 3G 來強制請求變慢(在 Firefox 中您可以選擇更慢的選項)
讓我們看看進展如何:
我們現在已經完成了!在第 5 部分中,我們將在視圖中添加一些測試,這可能是比測試客戶端程式碼更好的體驗:)
以上是使用 Django 和 HTMX 建立待辦事項應用程式 - 新增待辦事項的部分的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Python在遊戲和GUI開發中表現出色。 1)遊戲開發使用Pygame,提供繪圖、音頻等功能,適合創建2D遊戲。 2)GUI開發可選擇Tkinter或PyQt,Tkinter簡單易用,PyQt功能豐富,適合專業開發。

Python适合数据科学、Web开发和自动化任务,而C 适用于系统编程、游戏开发和嵌入式系统。Python以简洁和强大的生态系统著称,C 则以高性能和底层控制能力闻名。

2小時內可以學會Python的基本編程概念和技能。 1.學習變量和數據類型,2.掌握控制流(條件語句和循環),3.理解函數的定義和使用,4.通過簡單示例和代碼片段快速上手Python編程。

Python在web開發、數據科學、機器學習、自動化和腳本編寫等領域有廣泛應用。 1)在web開發中,Django和Flask框架簡化了開發過程。 2)數據科學和機器學習領域,NumPy、Pandas、Scikit-learn和TensorFlow庫提供了強大支持。 3)自動化和腳本編寫方面,Python適用於自動化測試和系統管理等任務。

兩小時內可以學到Python的基礎知識。 1.學習變量和數據類型,2.掌握控制結構如if語句和循環,3.了解函數的定義和使用。這些將幫助你開始編寫簡單的Python程序。

如何在10小時內教計算機小白編程基礎?如果你只有10個小時來教計算機小白一些編程知識,你會選擇教些什麼�...

使用FiddlerEverywhere進行中間人讀取時如何避免被檢測到當你使用FiddlerEverywhere...

Python3.6環境下加載Pickle文件報錯:ModuleNotFoundError:Nomodulenamed...


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

WebStorm Mac版
好用的JavaScript開發工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Dreamweaver Mac版
視覺化網頁開發工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。