- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
想知道为什么在通过表单助手创建时为表单创建的约束不直接包含在输入标记中?
说明(使用 Play 2.1):
型号:
public class Account {
@MaxLength(5)
private String id = "";
......
查看: @form(action = paths.Application.addAccount()) { @inputText(accountForm("id"), '_label -> "输入您的 ID:")
}
在 html 中自动呈现为:
不应该像这样渲染(实际上限制表单文本字段):
如何获取自动在表单中包含此类约束的代码?只是我并不认为在表单模型中定义 maxlength 并在 View 中定义单独的 maxlength 并不是一个好主意。
谢谢
最佳答案
如果我没理解错的话,听起来您正在寻求实现以下功能之一:
Play 的 HTML 模板引擎本身并不提供这种客户端即时表单验证。此功能需要通过 JavaScript 实现,而 JavaScript 生成并不是 Play 真正关心的问题。
如果您想逐步增强表单并提供客户端验证,则必须自己编写 JavaScript。当然,您可以使用一些库来帮助您完成此任务。例如,如果您已经在使用 jQuery,则可以使用其 validation plugin .
正如您在问题中提到的,最好仅在一个地方声明最大长度限制,而不是在客户端 JavaScript 代码和服务器端 Java 代码中重复声明。建议您保留在 Java 代码中声明的限制,但在 Controller 层中引入一个新操作,该操作返回包含此限制的 JSON 响应。然后可以在加载表单页面时通过 AJAX 调用此操作。
<小时/>不知道 maxlength
属性,谢谢 Saad 。如果您将最大长度限制作为输入参数提供给模板,则可以填充 input
元素的 maxlength
属性,如下所示:
@(accountForm: Form[Account], maxLength: Int)
...
@form(action = routes.Application.addAccount()) {
...
@inputText(
field = accountForm("id"),
args = '_label -> "Enter your id:", 'maxlength -> maxLength
)
...
}
...
可能有一种更优雅的方式将 maxLength
传递到 HTML 模板中(例如,使用 HTTP 上下文映射,或者将其作为 Account
表单上的公共(public)字段目的)。上面的代码片段只是演示了如何在模板中访问输入文本字段后正确生成它。
关于java - 限制条件未完全纳入 Play 2.1,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20813499/
我正在开发 Kext,它应该可以访问 struct proc->p_pid field 。问题是该结构仅在 XNU 源中定义,所以我面临 incomplete definition of type '
下面是 ES2015 类中的一个方法。 它不能是箭头函数,因为它是异步函数。 但由于它不是箭头函数,因此“this”不在范围内,因此我无法执行 setstate 之类的操作。 有人可以建议我如何将其纳
我想使用 Bootstrap 创建 NC 主题。 我通过 Visual Studio 2013 中的 Nugets 包管理器安装了 Bootstrap。然后我添加: Html.AppendScript
我是一名优秀的程序员,十分优秀!