Воспроизвести JavaScript-фреймворк как параметр шаблона scala
Я хочу повторно использовать функцию javascript, используя шаблон scala, поэтому мне нужно будет только передать другую функцию успеха / неудачи, но я не могу передать функцию javascript в шаблон scala. Обратите внимание, что я новичок в этом деле и даже не знаю, возможно ли то, что я делаю.
Это то, чего я пытаюсь достичь:
@(formId: String, success: JavaScript, fail: JavaScript)
<script type="text/javascript">
$("@formId").submit(function(e)
{
var data = $(this).serializeArray();
var action = $(this).attr("action");
$.ajax(
{
url : action,
type: "POST",
data : data,
success:function(data, textStatus, jqXHR) // Change contents to dynamic parameter for scala??? perhaps a javascript function to execute???
{
@success()
/*console.log("save succesfull, progress!")
alert('Save successfull, now move on!');*/
},
error: function(jqXHR, textStatus, errorThrown) // Change contents to dynamic parameter for scala??? perhaps a javascript function to execute???
{
//if fails
@fail()
/*console.log(jqXHR.responseText);
var errors = JSON.parse(jqXHR.responseText);
console.log(errors);
alert('Woops, something went wrong: ' + jqXHR.responseText);*/
}
});
e.preventDefault();
});
</script>
Как это будет использоваться:
@snippets.ajaxFormSubmit("#form",
function()
{
alert("Save successfull, now move on!");
},
function()
{
alert("Save failed!");
}
)
1 ответ
Решение
Вы можете передать любой контент в шаблон через тип HTML.
@(formId: String, success: Html, fail: Html)
<script type="text/javascript">
$("@formId").submit(function(e)
{
var data = $(this).serializeArray();
var action = $(this).attr("action");
$.ajax(
{
url : action,
type: "POST",
data : data,
success:function(data, textStatus, jqXHR) // Change contents to dynamic parameter for scala??? perhaps a javascript function to execute???
{
@success
},
error: function(jqXHR, textStatus, errorThrown) // Change contents to dynamic parameter for scala??? perhaps a javascript function to execute???
{
@fail
}
});
e.preventDefault();
});
</script>
В представлении клиента вы можете использовать его следующим образом:
@successFunc = {
alert("Save successfull, now move on!");
}
@failureFunc = {
alert("Save failed!");
}
@snippets.ajaxFormSubmit("#form", successFunc, failureFunc)