Aplikasi web Gin menghasilkan hanya satu templat

WBOY
Lepaskan: 2024-02-13 11:30:15
ke hadapan
907 orang telah melayarinya

Gin Web 应用程序仅渲染一个模板

Gin ialah rangka kerja web ringan yang digunakan secara meluas dalam pembangunan web dalam bahasa Go. Dalam Gin, aplikasi web biasanya hanya perlu memaparkan templat untuk melengkapkan paparan halaman. Reka bentuk ini membolehkan pembangun menumpukan lebih pada pelaksanaan logik perniagaan dan memudahkan proses pembangunan. Pada pendapat editor PHP Xiaoxin, ciri Gin ini bukan sahaja meningkatkan kecekapan pembangunan, tetapi juga mengurangkan penggunaan sumber, menjadikan aplikasi Web lebih cekap. Pada masa yang sama, Gin juga menyediakan banyak perisian tengah dan pemalam, memberikan pembangun dengan lebih berskala dan fleksibiliti. Ringkasnya, kesederhanaan dan ciri berkuasa Gin menjadikannya rangka kerja pilihan ramai pembangun.

Kandungan soalan

Saya mempunyai aplikasi web Gin yang mengandungi berbilang templat HTML berdasarkan set bahagian dan templat asas. Templat asas nampaknya berfungsi dengan baik dengan bahagian yang berkaitan, tetapi pandangan utama saya, log masuk, indeks dan pendaftaran tidak dipaparkan seperti yang diharapkan. Setiap kali saya mengakses titik akhir HTTP mana-mana daripada ini, hanya paparan daftar diberikan.

Kandungan yang tiada atau salah konfigurasi dalam fail berikut menyebabkan laluan saya gagal untuk memaparkan halaman yang diminta?

Projek saya mempunyai struktur berikut.

├── app
...
│   ├── handlers
│   │   ├── general
│   │   │   └── general.go
│   │   └── routes.go
│   ├── main.go
│   ├── reloadDev.sh
│   ├── static
│   │   ├── css
│   │   ├── img
│   │   └── js
│   └── templates
│       ├── home
│       │   ├── index.tmpl.html
│       │   ├── login.tmpl.html
│       │   └── register.tmpl.html
│       ├── layouts
│       │   └── base.tmpl.html
│       └── partials
│           ├── footer.tmpl.html
│           ├── head.tmpl.html
│           └── navbar.tmpl.html
Salin selepas log masuk

base.tmpl.html

{{ define "base" }}
<!DOCTYPE html>
<html lang="eng" data-bs-theme="dark">
    {{ template "head" . }}
    {{template "navbar" .}}
    <body>
    {{ block "content" . }}{{ end }}
    </body>
    {{template "footer" .}}
</html>
{{end}}
Salin selepas log masuk

Pendaftaran.tmpl.html

{{ template "base" . }}
{{ define "content" }}
<div class="container">
    <div class="row">
        <div class="col-md-6 offset-md-3">
            <h1>Register</h1>
            <form action="/register" method="post">
                <div class="mb-3">
                    <label for="username" class="form-label">Username</label>
                    <input type="text" name="username" id="username" class="form-control" placeholder="Username" required>
                </div>
                <div class="mb-3">
                    <label for="password" class="form-label">Password</label>
                    <input type="password" name="password" id="password" class="form-control" placeholder="Password" required>
                </div>
...SNIP...
                <button type="submit" class="btn btn-primary">Register</button>
            </form>
        </div>
    </div>
</div>
{{ end }}
Salin selepas log masuk

index.tmpl.html (Struktur log masuk adalah sama dengan kedua-dua ini.)

{{ template "base" . }}
{{ define "title" }}Home{{ end }}
{{ define "content" }}
<div class="container">
    <div class="row">
        <div class="col-md-6 offset-md-3">
            <p>Welcome to Astra Porta.</p>
            <p>Click <a href="//m.sbmmt.com/link/1b8e84dcae97ad25234484e38615c570">here</a> to login.</p>
        </div>
    </div>
</div>
{{ end }}
Salin selepas log masuk

Templat HTML digabungkan dengan binari menggunakan embed.FS.

//go:embed templates/partials/* templates/layouts/* templates/home/*
var files embed.FS

func main() {
    router := setupRouter()
    err := router.Run()
    if err != nil {
        panic(err)
    }
}

func setupRouter() *gin.Engine {
    router := gin.Default()
    subFS, e := fs.Sub(files, "templates")
    if e != nil {
        panic(e)
    }

tmpl := template.Must(template.ParseFS(
    subFS,
    "layouts/*.html",
    "partials/*.html",
    "home/*.html",
))
router.SetHTMLTemplate(tmpl)

router.StaticFS("/static", http.Dir("static"))

err := router.SetTrustedProxies(nil)
if err != nil {
    panic(err)
}
handlers.InitializeRoutes(&router.RouterGroup)
return router
}
Salin selepas log masuk

Halaman itu dipaparkan dalam laluan permohonan saya. Rujukan di sini memetakan kepada nama fail fail *.tmpl.html.

func SiteIndex(c *gin.Context) {
    c.HTML(http.StatusOK, "index.tmpl.html", nil)
}

func GetRegister(c *gin.Context) {
    c.HTML(http.StatusOK, "register.tmpl.html", nil)
}

func GetLogin(c *gin.Context) {
    c.HTML(http.StatusOK, "login.tmpl.html", nil)
}
Salin selepas log masuk

Penyelesaian

Untuk sesiapa lagi yang menghadapi masalah ini. Penyelesaian yang ditunjukkan oleh mkopriva dalam komen adalah betul. Saya mengalih keluar base.tmpl.html dan mengarang setiap paparan dengan bahagian dan halaman sasaran yang dikemas kini.

Tajuk

{{ define "header" }}
<!DOCTYPE html>
<html lang="eng" data-bs-theme="dark">
{{template "navbar" .}}
    <body>
    {{ block "content" . }}{{ end }}
        <head><meta charset="UTF-8">
            <meta name="viewport" content="width=device-width, initial-scale=1.0">
           ...SNIP...
            <title>App</title>
        </head>
{{end}}
Salin selepas log masuk

Footer

{{define "footer"}}

        <div class="container">
            <footer class="py-3 my-4" data-bs-theme="dark">
                <ul class="nav justify-content-center border-bottom pb-3 mb-3">
                    <li class="nav-item"><a href="/" class="nav-link px-2 text-body-secondary">Home</a></li>
                </ul>
                <p class="text-center text-body-secondary">© 2024 .</p>
            </footer>
        </div>
    </body>
</html>
{{end}}
Salin selepas log masuk

Halaman bermasalah

{{template "header"}}
<div class="container">
    <div class="row">
        <div class="col-md-6 offset-md-3">
            <p>Welcome to Astra Porta.</p>
            <p>Click <a href="//m.sbmmt.com/link/1b8e84dcae97ad25234484e38615c570">here</a> to login.</p>
        </div>
    </div>
</div>
{{template "footer"}}
Salin selepas log masuk

Atas ialah kandungan terperinci Aplikasi web Gin menghasilkan hanya satu templat. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:stackoverflow.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan