GoRazor is the Go port of the razor view engine originated from asp.net in 2011. In summay, GoRazor's:
- Consice syntax, no delineators like
<?
,<%
, or{{
.- Original Razor Syntax for asp.net.
- Able to mix go code in view template
- Insert code block to import & call arbitrary go modules & functions
- Code generation approach
- No reflection overhead
- Go compiler validation for free
- Strong type view model
- Embedding templates support
- Template layout (in progress)
Usage: ./gorazor.sh template_folder output_folder
Tested on mac, but it should be trivial to adapt gorazor.sh to gorazor.bat
for using in windows.
This port is essentially a re-port from razor's port in javascript: vash. It just modifies on vast's generation functions to emit go code instead of javascript code.
So, currently gorazor needs node.js to run, but it only needs node, no other npm modules.
@variable
to insert string variable into html template- variable could be wrapped by arbitary go functions
- variable inserted will be automatcially esacped
<div>Hello @user.Name</div>
<div>Hello @strings.ToUpper(req.CurrentUser.Name)</div>
Use raw
to skip escaping:
<div>@raw(user.Name)</div>
Only use raw
when you are 100% sure what you are doing, please always be aware of XSS attack.
@if .... {
....
}
@if .... {
....
} else {
....
}
@for .... {
}
@{
switch .... {
case ....:
<p>...</p>
case 2:
<p>...</p>
default:
<p>...</p>
}
}
Please use example for reference.
It's possbile to insert arbitary go code block in the template, like create new variable.
@{
username := u.Name
if u.Email != "" {
username += "(" + u.Email + ")"
}
}
<div class="welcome">
<h4>Hello @username</h4>
</div>
It's recommendation to keep clean separation of code & view. Please consider move logic into your code before creating a code block in template.
The first code block in template is strictly for decleration:
- imports
- model type
- layout (Not supported yet, but soon)
like:
@{
import (
kpm "kp/models"
)
var totalMessage int
var u *kpm.User
}
....
first code block must be at the begining of the template, i.e. before any html.
Any other codes inside the first code block will be ignored.
import must be wrapped in ()
, import "package_name"
is not yet supported.
The variables declared in first code block will be the models of the template, i.e. the parameters of generated function.
If your template doesn't need any model input, then just leave it blank.
As gorazor compiles tempaltes to go function, embedding another template is just calling the generated function, like any other go function.
However, if the template are designed to be embeded, it must be under helper
namespace, i.e. put them in helper
sub-folder.
So, using a helper template is similar to:
@if msg != "" {
<div>@helper.ShowMsg(msg)</div>
}
GoRazor won't HTML escape the output of helper.XXX
.
Please use example for reference.
TBA
- Template folder name will be used as package name in generated code
- Template file name must has the extension name
.gohtml
- Template strip of
.gohtml
extension name will be used as the function name in generated code, with fisrt letter Capitalized.- So that the function will be accessible to other modules. (I hate GO about this.)
- Helper templates must has the package name helper
Here is a simple example of gorazor templates and the corresponding generated codes.
TBA
@switch .... {
is buggy, plese use@{ switch ....
- closure is code block is buggy
- Refactor all the quick & dirty code
- Maybe reimplement vash compiler in go?
- Test suite
- Add tools, like monitor template changes and auto re-generate
- Performance benchmark
- Generate more function overloads, like accept additional buffer parameter for write
- Support direct usage of int/date variables in tempate?
- i.e. use @user.Level directly, instead of @gorazor.Itoa(user.Level)