golang text/template

GeminiGirl0604 · · 7569 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

https://juejin.im/post/5c403b98f265da612d1984c9

template包是数据驱动的文本输出模板,即在写好的模板中填充数据

模板

模板使用流程:

  • 定义模板
  • 解析模板
  • 数据驱动模板
package main

import (
    "os"
    "text/template"
)

func main() {
    //数据
    name := "Tom"
    //定义模板
    muban := "hello, {{.}}"
    //解析模板
    tmpl, err := template.New("test").Parse(muban)
    if err != nil {
        panic(err)
    }
    //数据驱动模板
    err = tmpl.Execute(os.Stdout, name)
    if err != nil {
        panic(err)
    }
}

output

hello, Tom

传入struct

实例

package main

import (
    "os"
    "text/template"
)

type Student struct {
    Name string
}

func main() {
    tom := Student{"Tom"}
    // name := "Tom"
    muban := "hello, {{.Name}}"
    tmpl, err := template.New("test").Parse(muban)
    if err != nil {
        panic(err)
    }
    err = tmpl.Execute(os.Stdout, tom)
    if err != nil {
        panic(err)
    }
}

output

hello, Tom

{{和}}之间的.代表传入模板的数据,根据传入的数据不同渲染不同的内容。
.可以代表golang中的任何类型,struct、map等。
{{和}}之间的内容统称为action,一共有两种:

  • 数据求值
  • 控制结构
    action求值的结果会直接复制到模板中,控制结构和我们写 Go 程序差不多,也是条件语句、循环语句、变量、函数调用等等...
    将模板成功解析(Parse)后,可以安全地在并发环境中使用,如果输出到同一个 io.Writer 数据可能会重叠(因为无法保证并发执行的先后顺序)。

Actions

注释

执行时会忽略。可以多行。注释不能嵌套,并且必须紧贴分界符始止

语法

{{/*comment*/}}

示例

package main

import (
    "os"
    "text/template"
)

func main() {
    name := "Tom"
    muban := "hello, {{.}}{{/*This is a comment of test template*/}}"
    tmpl, err := template.New("test").Parse(muban)
    if err != nil {
        panic(err)
    }
    err = tmpl.Execute(os.Stdout, name)
    if err != nil {
        panic(err)
    }
}

output

hello, Tom

裁剪空格

// 裁剪 content 前后的空格
{{- content -}}

// 裁剪 content 前面的空格
{{- content }}

// 裁剪 content 后面的空格
{{ content -}}

示例



有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:GeminiGirl0604

查看原文:golang text/template

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

7569 次点击  ∙  1 赞  
加入收藏 微博
1 回复  |  直到 2021-08-12 14:03:38
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传