在播放框架上将参数从视图传递到控制器
Passing parameter from view to controller on Play Framework
我想传递一个参数从一个视图到一个控制器,我不知道如何做到这一点。
这是我的观点:
#{extends 'crud.html' /}
#{form @DesglosesHorarios.updateValues(), class:"form-horizontal"}
<div id="add-date">
<input type="hidden" name="array-fechas" value="" />
<fieldset>
Fechas <input type="date" id="fecha-update" placeholder="Introduce fechas separadas por coma"/>
<button type="button" id="add-date-button" class="btn btn-primary">Añadir</button>
</fieldset>
</div>
</br>
<div id="value-dates">
<ul></ul>
</div>
<div id="fecha-error"><ul></ul></div>
<div class="form-actions">
<button type="submit" class="btn btn-primary"><i class="icon-ok icon-white"></i> &{'save'}</button>
<a class="btn" href="@{list()}"><i class="icon-remove"></i> &{'cancel'}</a>
</div>
#{/form}
这是我想在控制器中使用的函数:
public static void updatevalues(String[] fechas) {
for(String fecha : fechas){
updateXML(CalendarUtil.formatDate(CalendarUtil.ParseFecha(fecha)));
}
render(request.controller + "/updatevalues.html", fechas);
}
这是我用来捕获数据并将其放入数组的JavaScript代码:
fechas=[];
$("#add-date-button").on('click', function(){
exprfecha = /^([0-9]{2}'/[0-9]{2}'/[0-9]{4})$/;
values = $("#fecha-update").val().replace( /'s/g,"");
values = values.split(',');
errores=[];
for(i=0; i<values.length; i++){
if(values[i].match(exprfecha)){
if(fechas.indexOf(values[i]) == -1){
fechas.push(values[i]);
$("#value-dates ul").css("color","green");
$("#value-dates ul").append('<li>'+values[i]+'</li>');
}
}else{
errores.push(values[i]);
}
}
$("#fecha-error").empty();
if(errores.length != 0){
$("#fecha-error").css("color","red");
for(i=0;i<errores.length;i++){
$("#fecha-error").append('<li>'+errores[i]+" no tiene el formato adecuado (DD/MM/AAAA).</li>");
}
}
});
既然你的视图运行在客户端(浏览器),你可以使用HTTP POST (AJAX或普通)让你的服务器端(例如你的控制器)知道你的参数。我看到你在用jQuery,所以你可以用jQuery。Post将数据发送回控制器。在控制器中,您需要第二个操作方法来处理来自表单的这篇文章。看一下关于表单的Play教程,这里有几个旧的Play示例,包括表单处理。
当然。我认为会有更好的方法来做到这一点,这对我来说是一种个性化的解决方案,但这对我来说很有效。我看到了那个参数。body给了我一个这样的字符串:authenticityToken=8a10c96e3b2f16d68eee075e268a6b3886b9bc64&fecha%22=15%2F07%2F2015
所以我只使用了这个参数。从字符串中获取我需要的内容,并对其进行处理以获得日期。
String [] body = params.get("body").split("=");
String paramfechas = body[2];
paramfechas = paramfechas.replace("%2F", "/").replace("%2C", ",");
List<String> fechas = new ArrayList<String>();
String [] fechas = paramfechas.split(",");
通过这种方式,我获得了我想要的格式(DD/MM/YYYY)的日期(或多个日期,取决于params.body中有多少个日期)
相关文章:
- 将范围添加到角度种子默认视图控制器时,测试套件现在失败
- 设置子视图控制器 EmberJS
- 使用emberjs测试视图控制器
- UIwebview图片到新的视图控制器
- 节点.js中的模型-视图-控制器模式
- 如何通过不同的视图/控制器在特定元素上设置 ng-show
- Extjs 5.1:视图控制器中的方法未调用
- 视图控制器和恩约
- 如何在路由更改之间维护视图(控制器)状态
- 角度.js分页过滤的数据并显示总项目,而无需在视图/控制器中复制代码
- 嵌套视图控制器和ng-click-AngularJs
- 视图/控制器不会使用 push() 函数刷新,使用 angularjs 中的 socket.io
- 如何在状态管理器视图控制器中传递已解析的依赖项
- 建议:在JavaScript中难以使用模型视图控制器
- 在Angular JS中动态加载视图/控制器
- 如何将数据从主控制器发射到角度视图控制器
- 如何在Rails视图控制器中访问HTML5本地存储
- 在Angular中,如何重新初始化视图'控制器中的$scope变量?
- 跨视图控制器传输值不工作
- 视图控制器需要:属性不工作