输入类型=“日期”百里香

时间:2016-08-01 08:16:53

标签: java hibernate date input thymeleaf

我需要向我的实体添加日期,并让用户以网络形式设置它。 此字段默认需要填写今天的日期。

1. <input type="date" value="2016-08-01"> 

显示为默认设置的正确日期

2. <input type="date" th:value="${startDate}"> 

显示没有任何值的日期选择器(注意:String startDate =“2016-08-01”;)

3. <input type="date" th:field="${startDate}"> 

生成400错误(错误请求)(注意:日期startDate = new Date();)

所以,问题是:如何使用百日咳作为输入日期?

  • 我可以使用Date()数据类型来输入和存储这些数据吗?
  • 我需要在表单中设置“th:field”吗?
  • 我需要以相同的形式设置“th:value”吗?

我的控制人员:

@RequestMapping("/project_new")
public String createProject(Model model) {
    Project project = new Project ();
    List<Role> roles = mRoleService.findAll();

    project.setStart(new Date());

    model.addAttribute("page_title", "create project");
    model.addAttribute("roles", roles);
    model.addAttribute("statuses", Status.values());
    model.addAttribute("project", project);
    return "project_new";
}

@RequestMapping(value = "/project_new", method = RequestMethod.POST)
public String createProject(@ModelAttribute Project project, Model model) {
    // Fill id field for project.rolesNeeded
    mRoleService.setRolesId(project.getRolesNeeded());
    project.fixCollaboratorsAndRoles();

    mProjectService.save(project);
    return "redirect:/";
}

我的模板:

<form th:action="@{/project_new}" method="post" th:object="${project}">
  <div class="project-list single">
    <label for="name">Name:</label>
    <input type="text" id="name" required="true" th:placeholder="*{name}" th:value="*{name}" th:field="*{name}"/>
    <label for="description">Description:</label>
    <textarea rows="5" id="description" type="text"  required="true" th:placeholder="*{description}" th:value="*{description}" th:field="*{description}"/>

    <label for="date-started">Date started:</label>
    <input type="date" th:value="${project.start}" th:field="${project.start}" id="date-started"/>

    <div>
      <label for="project_status">Project Status:</label>
      <div class="custom-select">
        <span class="dropdown-arrow"></span>
        <select th:field="*{status}" id="project_status">
          <option th:each="s : ${statuses}" th:value="${s}" th:text="${s}">Active</option>
        </select>
      </div>
    </div>

  <div class="roles-collaborators">
    <ul class="checkbox-list">
      <li th:if="${role.name} ne 'Undefined'" th:each="role : ${roles}">
      <input type="checkbox"  th:value="${role}" th:field="${project.rolesNeeded}" class="checkbox"/>
      <span th:text="${role.name}" th:value="${role}" class="checkbox">Developer</span>
      </li>
    </ul>
  </div>

  <div class="actions">
    <button type="submit" class="button">Save</button>
    <a th:href="@{/}" class="button button-secondary">Cancel</a>
  </div>
</div>
</form>

项目实体:

@Entity
public class Project {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;

@NotNull
@Size (min = 3)
private String name;

@Column(columnDefinition="TEXT")
private String description;

@Column
private Status status;

@Column
private Date start;

@ManyToMany
@LazyCollection(LazyCollectionOption.FALSE)
private List<Role> rolesNeeded;

@ManyToMany
@LazyCollection(LazyCollectionOption.FALSE)
private List<Collaborator> collaborators;

public Date getStart() {
    return start;
}

public void setStart(Date start) {
    this.start = start;
}

2 个答案:

答案 0 :(得分:18)

查看错误日志中的注释,似乎是 String java.util.Date 之间的转换问题。在Thymeleaf GitHub中搜索了一段时间后,我看到了两个可以解释如何在这种情况下继续进行的问题:

  • 讨论转换,包括this issue中的日期。
  • 解释了转化的实施情况here

从最后一点开始,我在项目类的开始日期添加了一个注释:

// This is "org.springframework.format.annotation.DateTimeFormat"
@DateTimeFormat(pattern = "yyyy-MM-dd")
private Date start;

之后,我能够在您的控制器POST方法中收到日期。

考虑到你还需要改变你的价值&#34;和&#34; th:field&#34;模板中的日期值从 $ {project.start} * {start} 的属性正如我在名称中所做的那样在评论中写的< / em>和 description 字段。

答案 1 :(得分:0)

使用字符串代替日期

@DateTimeFormat(pattern = "yyyy-MM-dd")<br>
private String fromDate;