播放2 - 没有助手的模板

时间:2012-08-26 15:37:31

标签: java html templates scala playframework-2.0

@inputText(
                signupForm("email"), '_label -> "Email",
                '_help -> "Enter a valid email address."
            )

我如何用纯HTML写这个?

我不知道如何将值添加到signupForm,以便我可以在我的控制器中使用bindfromRequest()(在html中)

编辑:

我通常使用这种方法

final static Form<User> signupForm = form(User.class);

和绑定过程

Form<User> filledForm = signupForm.bindFromRequest();

我的渲染表单如下所示:

<div class="control-group ">
  <label class="control-label" for="email">Email</label>
  <div class="controls">

    <input type="text" id="email" name="email" value="" >

    <span class="help-inline"></span>
  </div>
</div>

这对我有用我只是好奇如何使用纯HTML,所以我可以创建自己的小助手。

EDIT2:

public static Result blank() {
        return ok(form.render(signupForm));
    }

并在模板中

@(signupForm: Form[User])

编辑3:

我不知道这是否有帮助,但助手看起来像这样。 (对于inputtext) 我只是不知道这意味着什么,scala对我来说看起来真的很神秘。

@(field: play.api.data.Field, args: (Symbol,Any)*)(implicit handler: FieldConstructor, lang: play.api.i18n.Lang)

@input(field, args:_*) { (id, name, value, htmlArgs) =>
    <input type="text" id="@id" name="@name" value="@value" @toHtmlArgs(htmlArgs)>
}

1 个答案:

答案 0 :(得分:4)

使用浏览器检查Play播放的源代码,并将HTML复制/粘贴到模板中。

一般来说,最有趣的是为手动创建的字段正确插入值:

<input type="text" name="email" value='@signupForm.field("email").value' />

设置正确的name attribut也很重要,否则在控制器中填充Form将会失败。

编辑:

当然,在空白操作中你的signupForm是空的,这是正常的,没有任何价值,在下一个动作中,我们将它命名为saveBlank,你需要填写表格中的请求数据,验证并保存。如果表单中存在错误,则需要再次使用绑定到以前请求的表单的数据呈现form.scala.view

public static Result saveBlank(){
    signupForm = signupForm.bindFromRequest();
    if (signupForm.hasErrors()){
        return badRequest(form.render(signupForm));
    }

    User user = new User();
    user = signupForm.get();
    user.save();

    return ok("user saved);
}

当然,如果您想要编辑现有用户,则必须使用来自DB的数据预填充,即:

public static Result edit(Long id){
    signupform = signupForm.fill(User.find.byId(id));
    return ok(form.render(signupForm));
}

(注意:我是从头顶写的,所以如果没有拼写错误或错误,请检查一下)

最后,您不需要在每种情况下都使用Form对象,您也可以使用DynamicForm

public static Result saySomething(){
    DynamicForm df = form().bindFromRequest();
    return("you entered :" + df.get("email"));
}

甚至是一行:

public static Result sayShorter(){
    return("you entered :" + form().bindFromRequest().get("email"));
}