Ajax.BeginForm не отображает модальную загрузку функцией onBegin после публикации
У меня есть вид входа в MVC с Ajax.BeginForm. Я хочу показать модальное диалоговое окно начальной загрузки в методе OnBeing, и после завершения действия я хочу закрыть диалоговое окно начальной загрузки. Проблема в том, что при отправке формы диалоговое окно не отображается. Action Controller работает отлично! В чем я не прав?
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>@ViewBag.Title - B.Bring</title>
@Styles.Render("~/Content/css")
<link href="@Url.Content("~/Content/Login/Login.css")" rel="stylesheet" type="text/css"/>
<script src="~/Scripts/jquery-1.11.1.min.js"></script>
<script src="~/Scripts/respond.min.js"></script>
<script src="~/Scripts/bootstrap.min.js"></script>
<script src="http://ajax.aspnecdn.com/ajax/mvc/3.0/jquery.unobtrusive-ajax.js"></script>
<script src="~/Scripts/jquery.validate.min.js"></script>
<script src="~/Scripts/jquery.validate.unobtrusive.min.js"></script>
<script src="~/Scripts/bootswatch.js"></script>
<script type="text/javascript">
function openProgressDialog() {
//alert('xczc');
$('#progressModal').modal({
keyboard: true,
show: true,
backdrop: true
})
return true;
}
function closeProgressDialog() {
$('#progressModal').modal({
show: false
})
return true;
}
function onBegin()
{
$("#btnlogin").button('loading');
}
//$(document).ready(function() {
// $('#form0').submit(function() {
// openProgressDialog();
// //var form = $(this);
// //var url = form.attr('action');
// //var formData = form.serialize();
// //$.post(url, formData, function(result) {
// // // Do something with result
// //});
// return false;
// });
//});
</script>
</head>
<body>
@*<div id="fullscreen_bg" class="fullscreen_bg"></div>*@
<div class="container">
<button class="btn btn-primary" onclick="openProgressDialog()">test call modal (work!)</button>
<div id="loginbox" style="margin-top:50px;" class="mainbox col-md-6 col-md-offset-3 col-sm-8 col-sm-offset-2">
<div class="panel panel-info panel-default">
<div class="panel-heading">
<div class="panel-title"><span class="glyphicon glyphicon-globe"></span> @BBring.Shared.GlobalVariables.ApplicationName - Login</div>
</div>
@using (Ajax.BeginForm("Login", "Account", null, new AjaxOptions { HttpMethod = "POST", InsertionMode = InsertionMode.Replace, OnBegin = "return openProgressDialog();", OnComplete="return closeProgressDialog();" LoadingElementId = "divLoading", LoadingElementDuration = 1000 }))
{
@Html.ValidationSummary(true, "", new { @class = "text-danger" })
@Html.AntiForgeryToken()
<div class="panel-body" style="padding-top:30px">
<div style="display:none" id="login-alert" class="alert alert-danger col-sm-12">
</div>
@Html.ValidationMessageFor(m => m.Username, "", new { @class = "text-danger" })
<div style="margin-bottom: 25px" class="input-group">
<span class="input-group-addon"><i class="glyphicon glyphicon-user"></i></span>
@Html.TextBoxFor(m => m.Username, new { @class = "form-control", @placeholder = "username" })
</div>
@Html.ValidationMessageFor(m => m.Password, "", new { @class = "text-danger" })
<div style="margin-bottom: 25px" class="input-group">
<span class="input-group-addon"><i class="glyphicon glyphicon-lock"></i></span>
@Html.PasswordFor(m => m.Password, new { @class = "form-control", @placeholder = "password" })
</div>
<div class="input-group">
<div class="checkbox">
<label>
<input id="login-remember" type="checkbox" name="remember" value="1"> Ricordami l'account
</label>
</div>
</div>
</div>
<div class="panel-footer">
<div class="bs-component text-right">
<div id="divLoading" style="display:none">
<img src="~/Content/Image/dx-spinner.png" />
</div>
<button id="btnlogin" type="submit" class="btn btn-primary" data-toggle="tooltip" data-placement="top" title="Accedi a BBring" data-loading-text="Login..."><span class="glyphicon glyphicon-log-in"></span> Login</button>
<button type="reset" class="btn btn-default" data-toggle="tooltip" data-placement="top" title="" data-original-title="Ripulisci i campi"><span class="glyphicon glyphicon-refresh"></span> Reset</button>
</div>
</div>
}
</div>
</div>
<div id="progressModal" class="modal" role="dialog" tabindex="-1" style="display:none">
<div class="modal-dialog modal-sm">
<div class="modal-content">
<div class="modal-body">
<div class="progress">
<div class="progress-bar progress-bar-striped active" role="progressbar" aria-valuenow="100" aria-valuemin="0" aria-valuemax="100" style="width: 100%">
<span class="sr-only">45% Complete</span>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</body>
</html>
1 ответ
Убедитесь, что на странице есть два тега.
скрипт<script type="text/javascript" src="//netdna.bootstrapcdn.com/twitter-bootstrap/2.1.0/js/bootstrap.min.js"></script>
CSS Ссылка<link href="//netdna.bootstrapcdn.com/twitter-bootstrap/2.1.0/css/bootstrap-combined.min.css" rel="stylesheet">
JQuery
$(document).ready(function () {
$("#progressModal").modal({
keyboard: true,
show: false,
backdrop: 'static'
});
function openProgressDialog() {
$('#progressModal').modal("show");
return true;
}
function closeProgressDialog() {
$('#progressModal').modal("close")
return true;
}
$("input").click(function () {
openProgressDialog();
});
});