-2

这可能是一个非常基本的问题,因为我根本不熟悉网络编程。我正在尝试使用 html 模板创建一个表格,该表格的内容是通过 go 脚本填充的。我的问题是标签没有落在我想要的地方。这是用于 html 模板的 html

<h1>Exchange Rate for {{.Title}}</h1>

<form action="/dateShow/react" method="POST">
<table>
    <tr>
        <td>From</td>
        <td>To</td>
        <td>Rate</td>
        <td>7-day avg</td>
    </tr>{{.Data}}
</table>
<div><input type="submit" value="Save"></div>
</form>

我期待 GO 脚本会在第一个“tr”标签之后和“table”标签内打印“数据”。相反,这就是我得到的

<html><head></head><body><h1>Exchange Rate for 2018-07-02</h1>

<form action="/dateShow/react" method="POST">
&lt;tr&gt;&lt;td&gt;usd&lt;/td&gt;&lt;td&gt;idr&lt;/td&gt;&lt;td&gt;15.000000&lt;/td&gt;&lt;td&gt;14.238334&lt;/td&gt;&lt;/tr&gt;&lt;tr&gt;&lt;td&gt;usd&lt;/td&gt;&lt;td&gt;sgd&lt;/td&gt;&lt;td&gt;1.320000&lt;/td&gt;&lt;td&gt;1.310000&lt;/td&gt;&lt;/tr&gt;
<table>
    <tbody><tr>
        <td>From</td>
        <td>To</td>
        <td>Rate</td>
        <td>7-day avg</td>
    </tr></tbody></table>
<div><input type="submit" value="Save"></div>
</form></body></html>

这太奇怪了,因为“标题”部分工作正常并降落在我想要的地方。但身体并非如此

4

1 回答 1

0

只需将整个汇率片段传递给模板,并使用range它来迭代它。

例如,如果您有如下结构:

var ExchangeRates []ExchangeRate

type ExchangeRate struct {
    From            string
    To              string
    Rate            float64
    SevenDayAverage float64
}

您将传递ExchangeRates给模板,模板可能如下所示:

<table>
    <tbody><tr>
        <td>From</td>
        <td>To</td>
        <td>Rate</td>
        <td>7-day avg</td>
    </tr>
    {{range .ExchangeRates}}
    <tr>
        <td>{{.From}}</td>
        <td>{{.To}}</td>
        <td>{{.Rate}}</td>
        <td>{{.SevenDayAverage}}</td>
    </tr>
    {{end}}
    </tbody>
</table>
于 2018-10-29T13:40:21.420 回答