Go Web開發框架實踐:模板渲染與靜態資源服務

Gin 不僅適合構建 API 服務,也支持 HTML 模板渲染和靜態資源托管,使其可以勝任中小型網站開發任務。


一、模板渲染基礎

1. 加載模板文件

使用?LoadHTMLGlob?或?LoadHTMLFiles?方法加載模板:

r?:=?gin.Default()
r.LoadHTMLGlob("templates/*")?//?支持通配符

或:

r.LoadHTMLFiles("templates/index.tmpl",?"templates/user.tmpl")
2. 定義模板文件(templates/index.tmpl)
<!DOCTYPE?html>
<html>
<head><title>{{?.Title?}}</title>
</head>
<body><h1>Hello,?{{?.User?}}</h1>
</body>
</html>
3. 渲染模板響應
r.GET("/",?func(c?*gin.Context)?{c.HTML(200,?"index.tmpl",?gin.H{"Title":?"首頁","User":??"Gopher",})
})

二、模板語法簡介(兼容 Go 的 html/template)

1. 輸出變量
<p>{{?.Name?}}</p>
2. 條件語句
{{?if?.Login?}}<p>Welcome?back!</p>
{{?else?}}<p>Please?login.</p>
{{?end?}}
3. 循環遍歷
<ul>{{?range?.Items?}}<li>{{?.?}}</li>{{?end?}}
</ul>
4. 使用管道函數
<p>{{?.Content?|?html?}}</p>

三、自定義模板函數

r.SetFuncMap(template.FuncMap{"formatDate":?func(t?time.Time)?string?{return?t.Format("2006-01-02")},
})
r.LoadHTMLGlob("templates/*")

模板中使用:

<p>發布日期:{{?.CreatedAt?|?formatDate?}}</p>

四、靜態資源服務

1. 基礎靜態目錄映射

將?/static?路徑映射到本地?assets?目錄:

r.Static("/static",?"./assets")

訪問方式:

http://localhost:8080/static/css/style.css
2. 映射單個文件(如 favicon)
r.StaticFile("/favicon.ico",?"./assets/favicon.ico")

五、模板熱重載(開發調試推薦)

開發階段可使用第三方工具(如?air)實現模板與代碼熱重載,提升效率。

安裝:

go?install?github.com/cosmtrek/air@latest

運行:

air

六、示例:構建一個帶靜態資源和模板頁面的簡單博客首頁

func?main()?{r?:=?gin.Default()r.LoadHTMLGlob("templates/*")r.Static("/static",?"./assets")r.GET("/",?func(c?*gin.Context)?{posts?:=?[]string{"Go?入門",?"Gin?實戰",?"部署技巧"}c.HTML(200,?"index.tmpl",?gin.H{"Title":?"Golang?博客","Posts":?posts,})})r.Run()
}

模板內容:templates/index.tmpl

<!DOCTYPE?html>
<html>
<head><title>{{?.Title?}}</title><link?rel="stylesheet"?href="/static/css/style.css">
</head>
<body><h1>{{?.Title?}}</h1><ul>{{?range?.Posts?}}<li>{{?.?}}</li>{{?end?}}</ul>
</body>
</html>

七、小結

功能優點說明
模板渲染使用 Go 原生?html/template,安全高效
支持條件與循環動態頁面結構易于控制
靜態資源托管支持 JS、CSS、圖片等靜態內容一鍵映射
自定義模板函數靈活擴展渲染邏輯

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/86277.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/86277.shtml
英文地址,請注明出處:http://en.pswp.cn/web/86277.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

緩存與加速技術實踐-Kafka消息隊列

目錄 #1.1消息隊列 1.1.1什么是消息隊列 1.1.2消息隊列的特征 1.1.3為什么需要消息隊列 #2.1ksfka基礎與入門 2.1.1kafka基本概念 2.1.2kafka相關術語 2.1.3kafka拓撲架構 #3.1zookeeper概述介紹 3.1.1zookeeper應用舉例 3.1.2zookeeper的工作原理是什么&#xff1f; 3.1.3z…

鴻蒙前后端部署教程

第一步&#xff1a;部署Java后端 打開IDEA編輯器 第二步&#xff1a;用DevEco Studio運行鴻蒙端項目 然后按WinR鍵調出Win的命令行&#xff0c;輸入ipconfig 打開后端IDEA可以查看數據庫情況&#xff0c;如下圖

Python 常用定時任務框架介紹及代碼舉例

文章目錄 Python 常用定時任務框架簡介&#x1f9e9; 一、輕量級方案&#xff08;適合簡單任務&#xff09;1. **schedule庫** ?? 二、中級方案&#xff08;平衡功能與復雜度&#xff09;2. **APScheduler**3. **Celery Celery Beat** &#x1f680; 三、異步專用方案&#…

使用redis服務的redisson架構實現分布式鎖

加鎖 /*** 嘗試為指定的許可證 ID 獲取分布式鎖。如果鎖已被占用&#xff0c;則立即拋出業務異常。** param licenseId 需要加鎖的許可證 ID&#xff08;即鎖名稱&#xff09;* return true 表示成功獲取鎖&#xff0c;但請注意&#xff1a;* 鎖實際持有時間為 30 秒…

HTML表格元素

HTML表格元素深度解析與實戰應用 一、表格基本結構與語義化 1. 基礎表格元素詳解 <table> 容器元素 核心作用&#xff1a;定義表格容器重要屬性&#xff1a; border&#xff1a;已廢棄&#xff0c;應使用CSS設置邊框aria-label/aria-labelledby&#xff1a;為屏幕閱讀…

如何使用 Dockerfile 創建自定義鏡像

使用 Dockerfile 創建自定義鏡像的過程非常清晰&#xff0c;通常包括定義基礎鏡像、安裝依賴、復制代碼、設置環境變量和啟動命令等步驟。下面詳細講解從零創建自定義鏡像的完整流程。 一、什么是 Dockerfile&#xff1f; Dockerfile 是一個文本文件&#xff0c;定義了如何構建…

設置AWS EC2默認使用加密磁盤

問題 EC2磁盤需要使用默認加密。這里需要設置一下默認加密。 EC2

【樹的概念及其堆的實現】

樹的概念及其堆的實現 1.樹的概念2.樹的相關概念3.二叉樹的概念4. 滿二叉樹和完全二叉樹5.二叉樹的存儲結構6.二叉樹順序結構的實現的7.堆的結構及其實現 1.樹的概念 樹是一種非線性的數據結構&#xff0c;它是由n&#xff08;n>0&#xff09;個有限結點組成一個具有層次關系…

鴻蒙系統(HarmonyOS)經典紅色風格登錄頁布局

預覽 簡介 基于鴻蒙系統&#xff08;HarmonyOS&#xff09;開發的現代化登錄界面&#xff0c;采用了科技感十足的紅色主題設計。該界面結合了流暢的動畫效果、精心設計的視覺元素和人性化的交互體驗&#xff0c;為用戶提供了一個安全、美觀且易用的登錄入口。 &#x1f3a8; …

C++虛函數多態

class C{ public:void x1(){};void x2(){};};C c; cout << sizeof(c) <<"\n";1字節 class D{ public:void x1(){};void x2(){};virtual void x3(){};//void *vptr看不見的虛函數表指針 }; D d; cout << sizeof(d) <<"\n";8字節類A…

新編輯器編寫指南--給自己的備忘

歡迎使用Markdown編輯器 你好&#xff01; 這是你第一次使用 Markdown編輯器 所展示的歡迎頁。如果你想學習如何使用Markdown編輯器, 可以仔細閱讀這篇文章&#xff0c;了解一下Markdown的基本語法知識。 新的改變 我們對Markdown編輯器進行了一些功能拓展與語法支持&#x…

目標檢測neck算法之MPCA和FSA的源碼實現

目標檢測neck算法之MPCA和FSA的源碼實現 使用BIBM2024 Spatial-Frequency Dual Domain Attention Network For Medical Image Segmentation的Frequency-Spatial Attention和Multi-scale Progressive Channel Attention改進neck. 接下來&#xff0c;我將講解它的源碼操作的實現…

MyBatis-Plus的3.5.7和PageHelper的那個版本對應

MyBatis-Plus的3.5.7和PageHelper的那個版本對應 根據你的知識庫中提到的信息&#xff1a; MyBatis-Plus 3.5.7 使用的是 JSqlParser 4.6 版本。PageHelper 若使用了不同版本的 JSqlParser&#xff08;如 4.7&#xff09;&#xff0c;會導致沖突。 ? 推薦對應關系 為了保證…

Apifox 6 月產品更新|支持 AI 能力、交互優化、在線文檔新增 SEO 設置、gRPC 項目支持前/后置操作

在 2025 年的 API 開發領域&#xff0c;Apifox 作為一款集 API 設計、調試、Mock 和測試于一體的協作平臺&#xff0c;已成為開發者的“得力助手”。然而&#xff0c;隨著業務需求的不斷增長&#xff0c;開發者對工具的效率和功能提出了更高的要求。6 月份&#xff0c;Apifox 推…

Acrobat JavaScript 從瀏覽器到 PDF 環境的轉換

目錄 什么是 JavaScript?JavaScript 核心語言與 Acrobat 特定 API學習 JavaScript 核心語言的挑戰瀏覽器與 Acrobat JavaScript 的關鍵差異在 Acrobat 中運行 JavaScript 代碼替代瀏覽器特定函數的方法后續學習建議什么是 JavaScript? JavaScript 最初于 1995 年作為 Netsca…

OpenCV CUDA模塊設備層-----指數運算函數exp()

操作系統&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 編程語言&#xff1a;C11 算法描述 OpenCV 的 CUDA 設備端數學函數 中的一個內聯函數&#xff0c;用于在 GPU 上對 uchar1 類型&#xff08;單通道圖像像素&#xff09;執行指數運算…

C++面向對象5——C++關鍵字、構造函數與拷貝構造函數

this關鍵字 C關鍵字this的深度解析 1. this指針的本質 在C中&#xff0c;this是一個特殊的隱式指針&#xff0c;它存在于每個非靜態成員函數內部&#xff0c;指向調用該函數的當前對象。其類型為&#xff1a; 對于非const成員函數&#xff1a;ClassName* const&#xff08;…

人工智能專業:探索未來的智慧前沿

親戚家的小孩剛高考完&#xff0c;問我人工智能專業是學什么、做什么的。趁機就寫一篇吧&#xff01; 人工智能專業&#xff1a;探索未來的智慧前沿 人工智能&#xff08;Artificial Intelligence&#xff0c;簡稱AI&#xff09;無疑是當今最熱門、最具顛覆性的技術之一。它正…

618風控戰升級,瑞數信息“動態安全+AI”利劍出鞘

每年的618電商促銷季&#xff0c;都是各大電商平臺和商家的兵家必爭之地。數以億計的消費者涌入線上平臺&#xff0c;期待已久的優惠券、秒殺商品如潮水般涌現&#xff0c;海量交易在瞬間達成&#xff0c;無疑是一場商業狂歡。 然而&#xff0c;在這場狂歡背后&#xff0c;自動…

神經網絡的架構

神經網絡中的基本術語 以上圖為例&#xff0c;相關的術語描述如下&#xff1a; 最左邊的稱為輸?層&#xff0c;其中的神經元稱為輸?神經元&#xff1b;最右邊的&#xff0c;即輸出層包含有輸出神經元&#xff1b;本例中的輸出神經元只有一個&#xff1b;中間層&#xff0c;既…