Go 语言 Web 开发很简单:使用模板将视图与逻辑分离

简介: 我们的 Web 服务器由两部分构成:为在用户浏览器中运行的 HTML 和 JavaScript 前端代码提供服务;接受 Web socket 连接以允许客户端进行通信。

使用 HTML 文件来改进我们的代码

改进 main.go 代码,如下:

package main
import (
  "log"
  "net/http"
)
func main() {
  http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
    w.Write([]byte(`
    <html>
      <head>
        <title>Hello</title>
      </head>
      <body>
        Hello, World!
      </body>
    </html>
    `))
  })
  // web 服务器开始
  if err := http.ListenAndServe(":8800", nil); err != nil {
    log.Fatal("ListenAndServe:", err)
  }
}


然后,像上一篇文章一样,使用命令 go run main.go 运行该代码。


打开浏览器,输入地址 http://localhost:8800/ ,就可以看到如下的进阶版 HelloWorld。


image.png


像这样将 HTML 代码嵌入到我们的 Go 代码中虽然是可行的,但它非常不合理、耦合度太高。


而且随着我们项目的增长,只会变得更糟。 接下来,我们将看看 HTML 模板如何帮助我们解决这个问题。

使用模板将视图与逻辑分离

模板允许我们将通用文本与特定文本混合,例如,加入用户名并对用户说 Hello。考虑以下模板:

Hello, {{userName}}!

然后,我们可以将 {{name}} 文本替换为真正的用户名。如果是用户“张三”登录了这个系统,就可能看到如下内容:

Hello, 张三!


Go 标准库有两个主要的模板包:一个称为 text/template 用于文本,另一个称为 html/template 用于 HTML。


html/template 包的作用与文本版本相同,只是它了解将数据注入模板的上下文。 这很有用,因为它避免了脚本注入攻击并解决了常见问题,例如必须为 URL 编码特殊字符。


最初,我们只想将 HTML 代码从 Go 代码中移动到它自己的文件中,但目前还不会混合任何文本。 template 包使加载外部文件变得非常容易,因此对我们来说是一个不错的选择。


在当前项目中新建一个 templates 文件夹,然后创建 hello.html 文件,把上一段 main.go 代码中 HTML 部分写入,但是需要做一点小小的改动才能生效:

<html>
    <head>
        <title>Hello</title>
    </head>
    <body>
        Hello, 张三!
    </body>
</html>


我们将编写自己的结构类型,负责加载、编译和交付我们的模板。 我们将定义一个接受文件名字符串的新类型,编译一次模板(使用 sync.Once 类型),保留对已编译模板的引用,然后响应 HTTP 请求。 您需要导入文本/模板、路径/文件路径和同步包以构建您的代码。sync.Once 类型保证我们作为参数传递的函数只会执行一次。


代码结构如下图:


image.png


templateHandler 结构是一个有效的 http.Handler 类型,因此我们可以将它直接传递给 http.Handle 函数并要求它处理与指定模式匹配的请求。 在前面的代码中,我们创建了一个 templateHandler 类型的新对象,将文件名指定为 hello.html,然后我们将其地址(使用运算符的 & 地址)传递给 http.Handle 函数。 我们不存储对新创建的 templateHandler 类型的引用,但这没关系,因为我们不需要再次引用它。


改进后的整体代码如下:

package main
import (
  "html/template"
  "log"
  "net/http"
  "path/filepath"
  "sync"
)
type templateHandler struct {
  once     sync.Once
  filename string
  templ    *template.Template
}
func (t *templateHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
  t.once.Do(func() {
    t.templ = template.Must(template.ParseFiles(filepath.Join("templates", t.filename)))
  })
  t.templ.Execute(w, nil)
}
func main() {
  http.Handle("/", &templateHandler{filename: "hello.html"})
  // web 服务器开始
  if err := http.ListenAndServe(":8800", nil); err != nil {
    log.Fatal("ListenAndServe:", err)
  }
}


使用 go run main.go 运行上面代码,然后在浏览器中输入网址,得到如下结果:


image.png


此时,我们的代码就很清爽了,也实现了同样的功能。

总结

又到了该做总结的时候了,从长期来看,开发就是需要做到高内聚低耦合,Go 代码和 HTML 模板的分离,其实就是代码逻辑与模板视图分开,方便项目的维护。

相关文章
|
3月前
|
前端开发 JavaScript 开发者
JavaScript:无处不在的Web语言
JavaScript:无处不在的Web语言
|
2月前
|
算法 Java Go
【GoGin】(1)上手Go Gin 基于Go语言开发的Web框架,本文介绍了各种路由的配置信息;包含各场景下请求参数的基本传入接收
gin 框架中采用的路优酷是基于httprouter做的是一个高性能的 HTTP 请求路由器,适用于 Go 语言。它的设计目标是提供高效的路由匹配和低内存占用,特别适合需要高性能和简单路由的应用场景。
263 4
|
2月前
|
开发框架 前端开发 Go
【GoGin】(0)基于Go的WEB开发框架,GO Gin是什么?怎么启动?本文给你答案
Gin:Go语言编写的Web框架,以更好的性能实现类似Martini框架的APInet/http、Beego:开源的高性能Go语言Web框架、Iris:最快的Go语言Web框架,完备的MVC支持。
380 1
|
6月前
|
缓存 JavaScript 前端开发
鸿蒙5开发宝藏案例分享---Web开发优化案例分享
本文深入解读鸿蒙官方文档中的 `ArkWeb` 性能优化技巧,从预启动进程到预渲染,涵盖预下载、预连接、预取POST等八大优化策略。通过代码示例详解如何提升Web页面加载速度,助你打造流畅的HarmonyOS应用体验。内容实用,按需选用,让H5页面快到飞起!
|
6月前
|
JavaScript 前端开发 API
鸿蒙5开发宝藏案例分享---Web加载时延优化解析
本文深入解析了鸿蒙开发中Web加载完成时延的优化技巧,结合官方案例与实际代码,助你提升性能。核心内容包括:使用DevEco Profiler和DevTools定位瓶颈、四大优化方向(资源合并、接口预取、图片懒加载、任务拆解)及高频手段总结。同时提供性能优化黄金准则,如首屏资源控制在300KB内、关键接口响应≤200ms等,帮助开发者实现丝般流畅体验。
|
前端开发 JavaScript Shell
鸿蒙5开发宝藏案例分享---Web页面内点击响应时延分析
本文为鸿蒙开发者整理了Web性能优化的实战案例解析,结合官方文档深度扩展。内容涵盖点击响应时延核心指标(≤100ms)、性能分析工具链(如DevTools时间线、ArkUI Trace抓取)以及高频优化场景,包括递归函数优化、网络请求阻塞解决方案和setTimeout滥用问题等。同时提供进阶技巧,如首帧加速、透明动画陷阱规避及Web组件初始化加速,并通过优化前后Trace对比展示成果。最后总结了快速定位问题的方法与开发建议,助力开发者提升Web应用性能。
|
6月前
|
JSON 开发框架 自然语言处理
【HarmonyOS Next之旅】基于ArkTS开发(三) -> 兼容JS的类Web开发(三)
本文主要介绍了应用开发中的三大核心内容:生命周期管理、资源限定与访问以及多语言支持。在生命周期部分,详细说明了应用和页面的生命周期函数及其触发时机,帮助开发者更好地掌控应用状态变化。资源限定与访问章节,则聚焦于资源限定词的定义、命名规则及匹配逻辑,并阐述了如何通过 `$r` 引用 JS 模块内的资源。最后,多语言支持部分讲解了如何通过 JSON 文件定义多语言资源,使用 `$t` 和 `$tc` 方法实现简单格式化与单复数格式化,为全球化应用提供便利。
262 104
|
6月前
|
JavaScript 前端开发 API
【HarmonyOS Next之旅】基于ArkTS开发(三) -> 兼容JS的类Web开发(二)
本文介绍了HarmonyOS应用开发中的HML、CSS和JS语法。HML作为标记语言,支持数据绑定、事件处理、列表渲染等功能;CSS用于样式定义,涵盖尺寸单位、样式导入、选择器及伪类等特性;JS实现业务逻辑,包括ES6语法支持、对象属性、数据方法及事件处理。通过具体代码示例,详细解析了页面构建与交互的实现方式,为开发者提供全面的技术指导。
284 104
|
6月前
|
开发框架 JSON 中间件
Go语言Web开发框架实践:路由、中间件、参数校验
Gin框架以其极简风格、强大路由管理、灵活中间件机制及参数绑定校验系统著称。本文详解其核心功能:1) 路由管理,支持分组与路径参数;2) 中间件机制,实现全局与局部控制;3) 参数绑定,涵盖多种来源;4) 结构体绑定与字段校验,确保数据合法性;5) 自定义校验器扩展功能;6) 统一错误处理提升用户体验。Gin以清晰模块化、流程可控及自动化校验等优势,成为开发者的优选工具。
|
6月前
|
开发框架 JSON 中间件
Go语言Web开发框架实践:使用 Gin 快速构建 Web 服务
Gin 是一个高效、轻量级的 Go 语言 Web 框架,支持中间件机制,非常适合开发 RESTful API。本文从安装到进阶技巧全面解析 Gin 的使用:快速入门示例(Hello Gin)、定义 RESTful 用户服务(增删改查接口实现),以及推荐实践如参数校验、中间件和路由分组等。通过对比标准库 `net/http`,Gin 提供更简洁灵活的开发体验。此外,还推荐了 GORM、Viper、Zap 等配合使用的工具库,助力高效开发。