5

提前感谢您的时间和帮助!

我正在尝试在 Play 2.0.4 中构建一个自定义表单字段,该字段使用此处找到的 twitter bootstrap datepicker 。

基本上,我正在尝试创建一个输出以下内容的自定义字段构造函数:

<div class="input-append date error" id="expires_field" data-date="" data-date-format="mm/dd/yyyy">
    <label for="expires_field">Expiration Date</label>
    <div class="input">
        <input class="span2" size="16" type="text" name="expires" id="expires" value="mm/dd/yyyy">
        <span class="add-on"><i class="icon-th"></i></span>
        <span class="help-inline"></span>
    </div>
</div>

但是,尽管在互联网上浏览了很多 - 我一直无法在 Play 2.0 中创建自定义表单字段,我仍然可以在其中验证和显示错误。

我认为,大多数情况下,我对文件需要在应用程序结构中的位置感到有些困惑。

任何帮助将不胜感激!

像素世界

4

2 回答 2

8

我也一直在为此苦苦挣扎,这就是我想出的:

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

@import play.api.i18n._
@import views.html.helper._

@elements = @{ new FieldElements(field.id, field, null, args.toMap, lang) }

<div class="control-group">
  <label class="control-label" for="@field.name">@elements.args.get('_label)</label>
  <div class="controls">
    <div class="input-append date" id="@field.id-picker" data-date="@field.value" data-date-format="@elements.args.get('format).getOrElse("mm/dd/yyyy")">
      <input type="text" name="@field.name" id="@field.id">
      <span class="add-on"><i class="icon-calendar"></i></span>
      <span class="help-inline">@elements.errors(elements.lang).mkString(", ")</span>
      <span class="help-block">@elements.infos(elements.lang).mkString(", ")</span> 
    </div>
  </div>
</div>

将其保存在文件 calendar.scala.html 中并像这样使用它:

@views.html.forms.calendar(
  myform("end"),
  '_showConstraints -> false,
  '_label -> Messages("label.end.date"),
  'format -> "dd/mm/yyyy"
)

然后在你的 JS 中:

$('#end-picker').datepicker({
  weekStart: 1
}).on('changeDate', function(ev){
  $('#end-picker').datepicker('hide');
});

id 的名称是用 field.name + "-picker" 生成的

此外,您可以使用 inputText:

@inputText(
  myform("start"),
  '_showConstraints -> false,
  '_label -> Messages("label.start.date"),
  'class -> "date-picker",
  Symbol("data-date-format") -> "mm/dd/yyyy"
)

希望能帮助到你

于 2012-12-12T15:10:59.827 回答
0

我解决这个问题的最简单方法是在我的 bean 级别定义一个注释(play.data.format.Formats):

@Formats.DateTime(pattern = "mm/dd/yyyy") 公共日期开始;

该框架负责在 HTML 中呈现。

于 2013-11-24T20:04:40.260 回答