
毫无疑问,模板的名称就是为模板 命名 。
到底有什么好处呢?只要您不想 引用 该模板,就没有关系。但是,如果要 引用 它,那么可以,您可以通过它的 名称 来引用它。
您什么时候要参考?当您想要将模板包含在另一个模板中时(例如,使用
{{template}} *** 作),或者您想使用执行特定模板Template.ExecuteTemplate()。
到目前为止,一切都很好,但是仍然缺少关键点。这不是明确/琐碎的:
template.Template值是
“已解析模板的表示形式” 。但是这里的措辞有点“不完善”。甲
template.Template值可以是(并且通常是) 的倍数,相关联的模板的集合
。
template.Template具有未导出的字段:
tmpl map[string]*Template // Map from name to defined templates.
此
tmpl字段包含所有其他关联的模板,这些模板对于模板可见,并且可以通过其 名称 来指代(是)。
当您使用或一次解析 多个 模板时,这些模板将以文件名命名,并且它们将自动关联(上述函数返回一个值,该值包含所有关联的已解析模板)。Doc
对此很清楚:
Template.ParseFiles()
Template.ParseGlob()
template.Template``Template.ParseFiles()
ParseFiles创建一个新的模板,并从命名文件中解析模板定义。返回的模板名称将具有第一个文件的基本名称和已解析的内容。[…]
当在不同目录中解析具有相同名称的多个文件时,提到的最后一个将是结果文件。例如,ParseFiles(“ a / foo”,“ b / foo”)将“ b
/ foo”存储为名为“ foo”的模板,而“ a / foo”不可用。
模板名称可以来自多个 位置 :
- 它可以来自文件名(如上所示)
- 可以明确指定(如果使用
{{define "somename"}}或{{block "somename"}}动作定义), - 或者可以将其定义为传递给
template.New()
(function)或Template.New()
(method)的参数。
让我们看一些例子:
func main() { t := template.Must(template.New("one").Parse(t1src)) template.Must(t.New("other").Parse(t2src)) // error checks omitted for brevity // Executes default, "one": t.Execute(os.Stdout, nil) // Executes explicit, "one": t.ExecuteTemplate(os.Stdout, "one", nil) // Executes explicit, "other": t.ExecuteTemplate(os.Stdout, "other", nil)}const t1src = `I'm some template.`const t2src = `I'm some OTHER template.`输出(在Go Playground上尝试):
I'm some template.I'm some template.I'm some OTHER template.
如果现在继续,然后将前两行更改为:
t := template.Must(template.New("one").Parse(t1src))t = template.Must(t.New("other").Parse(t2src))然后,这里发生的是我们为分配了一个新
template.Template值
t,这是解析的结果
t2src,因此这将是默认值,但是当两个模板关联时仍可以从中“到达”它们。输出更改为此(在Go
Playground上尝试):
I'm some OTHER template.I'm some template.I'm some OTHER template.
调用
template.New()(函数)将创建一个新模板,该模板没有关联。调用
Template.New()(方法)时,返回的模板将与(所有)调用该方法的模板相关联。
现在,让我们看一些有关“嵌入式”模板的示例。
func main() { t := template.Must(template.New("one").Parse(t1src)) template.Must(t.New("other").Parse(t2src)) template.Must(t.New("third").Parse(t3src)) t.Execute(os.Stdout, nil) t.ExecuteTemplate(os.Stdout, "one", nil) t.ExecuteTemplate(os.Stdout, "other", nil) t.ExecuteTemplate(os.Stdout, "embedded", nil) t.ExecuteTemplate(os.Stdout, "third", nil)}const t1src = `I'm some template. {{block "embedded" .}}I'm embedded in "one".{{end}}`const t2src = `I'm some OTHER template.`const t3src = `I'm the 3rd, including everything from "one": {{template "one"}}`输出(在Go Playground上尝试):
I'm some template. I'm embedded in "one".I'm some template. I'm embedded in "one".I'm some OTHER template.I'm embedded in "one".I'm the 3rd, including everything from "one": I'm some template. I'm embedded in "one".
现在应该很清楚模板名称的作用以及它的来源。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)