Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in
Toggle navigation
B
beego
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Commits
Issue Boards
Open sidebar
go
beego
Commits
328f4566
Commit
328f4566
authored
Aug 12, 2013
by
astaxie
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #150 from miraclesu/form
Support custom label for renderform
parents
50f3bd58
a37b2bdf
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
25 additions
and
10 deletions
+25
-10
utils.go
utils.go
+23
-8
utils_test.go
utils_test.go
+2
-2
No files found.
utils.go
View file @
328f4566
...
...
@@ -281,24 +281,39 @@ func RenderForm(obj interface{}) template.HTML {
fieldT
:=
objT
.
Field
(
i
)
tags
:=
strings
.
Split
(
fieldT
.
Tag
.
Get
(
"form"
),
","
)
label
:=
fieldT
.
Name
+
": "
name
:=
fieldT
.
Name
fType
:=
"text"
if
len
(
tags
)
>
0
&&
tags
[
0
]
==
"-"
{
continue
}
if
len
(
tags
)
==
1
&&
len
(
tags
[
0
])
>
0
{
name
=
tags
[
0
]
}
else
if
len
(
tags
)
>=
2
{
switch
len
(
tags
)
{
case
1
:
if
tags
[
0
]
==
"-"
{
continue
}
if
len
(
tags
[
0
])
>
0
{
name
=
tags
[
0
]
}
case
2
:
if
len
(
tags
[
0
])
>
0
{
name
=
tags
[
0
]
}
if
len
(
tags
[
1
])
>
0
{
fType
=
tags
[
1
]
}
case
3
:
if
len
(
tags
[
0
])
>
0
{
name
=
tags
[
0
]
}
if
len
(
tags
[
1
])
>
0
{
fType
=
tags
[
1
]
}
if
len
(
tags
[
2
])
>
0
{
label
=
tags
[
2
]
}
}
raw
=
append
(
raw
,
fmt
.
Sprintf
(
`%v: <input name="%v" type="%v" value="%v">`
,
fieldT
.
Name
,
name
,
fType
,
fieldV
.
Interface
()))
raw
=
append
(
raw
,
fmt
.
Sprintf
(
`%v<input name="%v" type="%v" value="%v">`
,
label
,
name
,
fType
,
fieldV
.
Interface
()))
}
return
template
.
HTML
(
strings
.
Join
(
raw
,
"</br>"
))
}
...
...
utils_test.go
View file @
328f4566
...
...
@@ -153,7 +153,7 @@ func TestRenderForm(t *testing.T) {
Id
int
`form:"-"`
tag
string
`form:"tag"`
Name
interface
{}
`form:"username"`
Age
int
`form:"age,text"`
Age
int
`form:"age,text
,年龄:
"`
Sex
string
Email
[]
string
Intro
string
`form:",textarea"`
...
...
@@ -167,7 +167,7 @@ func TestRenderForm(t *testing.T) {
output
=
RenderForm
(
&
u
)
result
:=
template
.
HTML
(
`Name: <input name="username" type="text" value="test"></br>`
+
`
Age:
<input name="age" type="text" value="0"></br>`
+
`
年龄:
<input name="age" type="text" value="0"></br>`
+
`Sex: <input name="Sex" type="text" value=""></br>`
+
`Intro: <input name="Intro" type="textarea" value="">`
)
if
output
!=
result
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment