Return 来自 select 的值,使用 FreeMarker
Return value from select using FreeMarker
我有一个表格:
<form action="user-fonts" method="post" ">
<select >
<#list fonts as font>
<option value=${font}>${font.nameFont?ifExists}</option>
</#list>
</select>
<input type="hidden" name="_csrf" value="${_csrf.token}" />
<div><input type="submit" value="Sign In"/></div>
</form>
如何获取我在表单上选择的控制器中的值?
@RequestMapping("/user-fonts")
public class MainController{
@GetMapping
public String main(@AuthenticationPrincipal User user, Model model)
{
Set<DBFont> fonts = user.getFont();
model.addAttribute("fonts", fonts);
return "Myfonts";
}
@PostMapping
public String mainPost(@ModelAttribute DBFont DBfont)
{
System.out.println(DBfont.getNameFont());
return "redirect:/user-fonts";
}
数据库中有一个值,但是我得到null
,如何return这个值?
您需要为 select 定义一个 name
属性,例如nameFont
:
<select name="nameFont">
这将发送字体 selected 值作为 POST 参数 nameFont
我有一个表格:
<form action="user-fonts" method="post" ">
<select >
<#list fonts as font>
<option value=${font}>${font.nameFont?ifExists}</option>
</#list>
</select>
<input type="hidden" name="_csrf" value="${_csrf.token}" />
<div><input type="submit" value="Sign In"/></div>
</form>
如何获取我在表单上选择的控制器中的值?
@RequestMapping("/user-fonts")
public class MainController{
@GetMapping
public String main(@AuthenticationPrincipal User user, Model model)
{
Set<DBFont> fonts = user.getFont();
model.addAttribute("fonts", fonts);
return "Myfonts";
}
@PostMapping
public String mainPost(@ModelAttribute DBFont DBfont)
{
System.out.println(DBfont.getNameFont());
return "redirect:/user-fonts";
}
数据库中有一个值,但是我得到null
,如何return这个值?
您需要为 select 定义一个 name
属性,例如nameFont
:
<select name="nameFont">
这将发送字体 selected 值作为 POST 参数 nameFont