1
0
View components in pure Go, that render to HTML 5. https://www.gomponents.com
Go to file
2020-09-23 22:05:59 +02:00
.github/workflows Try out codecov.io (#5) 2020-09-18 14:05:53 +02:00
assert Make NodeFunc and attr implement fmt.Stringer (#6) 2020-09-18 14:38:09 +02:00
attr Make attr.Classes a map type (#14) 2020-09-23 20:30:14 +02:00
el Add children varargs to h1-6, b, strong, i, em, img helpers (#15) 2020-09-23 20:35:16 +02:00
examples/simple Add simple example (#13) 2020-09-21 16:30:29 +02:00
.editorconfig Add better example in readme (#16) 2020-09-23 22:05:59 +02:00
.gitignore Add Makefile (#4) 2020-09-18 13:57:04 +02:00
go.mod Add first implementation of Node, El, Attr, Text 2020-09-13 22:50:19 +02:00
gomponents_test.go Add a test for attr.String (#12) 2020-09-21 16:07:39 +02:00
gomponents.go Add a Write function (#11) 2020-09-21 11:27:37 +02:00
LICENSE Add first implementation of Node, El, Attr, Text 2020-09-13 22:50:19 +02:00
Makefile Add Makefile (#4) 2020-09-18 13:57:04 +02:00
README.md Add better example in readme (#16) 2020-09-23 22:05:59 +02:00

gomponents

GoDoc codecov

gomponents are components of DOM nodes for Go, that can render to an HTML Document. gomponents aims to make it easy to build HTML pages of reusable components, without the use of a template language. Think server-side-rendered React, but without the virtual DOM and diffing.

The implementation is still incomplete, but usable. The API may change until version 1 is reached.

Usage

Get the library using go get:

go get -u github.com/maragudk/gomponents

Then do something like this:

package main

import (
	"fmt"
	"net/http"

	g "github.com/maragudk/gomponents"
	"github.com/maragudk/gomponents/attr"
	"github.com/maragudk/gomponents/el"
)

func main() {
	_ = http.ListenAndServe("localhost:8080", handler())
}

func handler() http.HandlerFunc {
	return func(w http.ResponseWriter, r *http.Request) {
		page := Page("Hi!", r.URL.Path)
		_ = g.Write(w, page)
	}
}

func Page(title, path string) g.Node {
	return el.Document(
		el.HTML(
			g.Attr("lang", "en"),
			el.Head(
				el.Title(title),
				el.Style(g.Attr("type", "text/css"), g.Raw(".is-active{font-weight: bold}")),
			),
			el.Body(
				Navbar(path),
				el.H1(title),
				el.P(g.Text(fmt.Sprintf("Welcome to the page at %v.", path))),
			),
		),
	)
}

func Navbar(path string) g.Node {
	return g.El("nav",
		el.A("/", attr.Classes{"is-active": path == "/"}, g.Text("Home")),
		el.A("/about", attr.Classes{"is-active": path == "/about"}, g.Text("About")),
	)
}

For more complete examples, see the examples directory.