新聞中心
Htmx 是一個庫,它允許你直接從 HTML 訪問現代瀏覽器功能,而不是使用 javascript。

讓客戶滿意是我們工作的目標,不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領域值得信任、有價值的長期合作伙伴,公司提供的服務項目有:空間域名、網絡空間、營銷軟件、網站建設、敘州網站維護、網站推廣。
要理解 htmx,首先讓我們看一下 HTML 中的 a 標簽:
Blog
這個標記會告訴瀏覽器:當用戶單擊此鏈接時,向 /blog 發(fā)出 HTTP GET 請求并將響應內容加載到瀏覽器窗口中。
然后我們再看下面的 HTML:
這告訴 htmx:當用戶單擊此按鈕時,向 /clicked 發(fā)出 HTTP POST 請求并使用響應中的內容將元素替換為 id 為 parent-div 的 DOM。
Htmx 將 HTML 的核心思想進行了擴展,為 HTML 語言提供了更多可能性:
- 現在任何元素,不僅僅是超鏈接和表單,都可以發(fā)出 HTTP 請求。
- 現在任何事件,不僅僅是點擊或表單提交,都可以觸發(fā)請求。
- 現在可以使用任何 HTTP verb,而不僅僅是GET 和POST。
- 現在任何元素,不僅僅是整個window 對象,都可以成為請求更新的目標。
請注意,當你使用 htmx 時,在服務器端你通常會使用 HTML 而非 JSON 進行響應。這會讓你使用原始 Web 編程模型,使用超文本作為應用程序狀態(tài)的引擎,甚至你也不需要真正理解這個概念。
另外如果你愿意,可以在使用 htmx 時使用 data- 前綴:
Click Me!
安裝
Htmx 是一個無依賴、面向瀏覽器的 JavaScript 庫。這意味著使用它就像在文檔頭部添加一個
npm
對于 npm 風格的構建系統,同樣你可以通過 npm 安裝 htmx:
npm install htmx.org
安裝后,你需要使用適當的工具來使用 node_modules/htmx.org/dist/htmx.js(或 .min.js),例如你可以將 htmx 與一些擴展和特定于項目的代碼捆綁在一起。
如果你使用 webpack 來管理你的 javascript:
- 通過你最喜歡的包管理器(如 npm 或 yarn)安裝 htmx。
- 在你的index.js 文件 import htmx。
import 'htmx.org';
如果要使用全局 htmx 變量(推薦),則需要將其注入到 window 作用域中:
- 創(chuàng)建一個定制的 JS 文件。
- 在index.js 文件中導入該文件。
import 'path/to/my_custom.js';
- 然后添加如下所示的代碼:
window.htmx = require('htmx.org');- 最后重新打包即可
AJAX
htmx 的核心是一組允許你直接從 HTML 發(fā)出 AJAX 請求的屬性:
- hx-get:向指定的 URL 發(fā)出 GET 請求。
- hx-post:向指定的 URL 發(fā)出 POST 請求。
- hx-put:向指定的 URL 發(fā)出 PUT 請求。
- hx-patch:向指定的 URL 發(fā)出 PATCH 請求。
- hx-delete:向指定的 URL 發(fā)出 DELETE 請求。
這些屬性都需要一個 URL 來向其發(fā)出 AJAX 請求,當元素被觸發(fā)時,該元素將向給定的 URL 發(fā)出指定類型的請求:
Put To Messages
這會告訴瀏覽器:當用戶點擊此 div 時,向 /messages 發(fā)出 PUT 請求并將響應加載到 div。
觸發(fā)請求
默認情況下,AJAX 請求由元素的 自然 事件觸發(fā):
- input?、textarea? 和select? 在change 事件上觸發(fā)。
- form 在提交事件上觸發(fā)。
- 其他元素都由click 事件觸發(fā)。
如果你想要不同的行為,可以使用 hx-trigger 屬性來指定哪個事件將觸發(fā)請求。
比如下面的一段代碼表示在鼠標進入時觸發(fā)到 /mouse_entered 的 POST 請求:
[Here Mouse, Mouse!]
HTMX 還有很多使用的方式,可以前往官方文檔 https://htmx.org/docs/ 了解更多。
示例
下面我們用幾個示例來簡單說明下 htmx 是如何使用的。
點擊加載數據
這個例子展示了如何在數據表格中實現點擊加載下一頁,關鍵是最后一行:
該行包含一個按鈕,該按鈕將用下一頁結果替換整行(其中將包含一個用于加載下一頁結果的按鈕)。
當點擊 Load More Agents... 按鈕后會加載一頁數據附加到表格中去。
延遲加載
這個例子展示了如何在頁面上延遲加載元素。我們從如下所示的初始狀態(tài)開始:
當我們加載圖表時,它會顯示一個進度指示器,然后通過 CSS 過渡加載圖表并逐漸淡入視圖:
.htmx-settling img {
opacity: 0;
}
img {
transition: opacity 300ms ease-in;
}該示例的效果就是先顯示一個加載的指示器,然后加載一張圖片出來,就是通常的延遲加載的效果。
Git 倉庫:https://github.com/bigskysoftware/htmx。
分享標題:不使用Javascript也可以和瀏覽器進行交互?
文章鏈接:http://m.5511xx.com/article/cdichde.html


咨詢
建站咨詢
