淘汰赛和 ASP.NET MVC 4
Knockout and ASP.NET MVC 4
我被告知使用MVC4,Bootstrap和KNOCKOUT构建Web应用程序。顺便说一下,我对这三个都是全新的。请耐心等待,因为这可能是很长的帖子。我有3个页面:一个创建页面,一个列表页面和一个编辑页面。创建页面工作正常,但列表页面是我面临大量问题的地方。列表页面列出了所有数据。我在这里面临的第一个问题是正在删除数据,但我必须刷新页面才能看到删除更新。其次,编辑按钮不会重定向到编辑页面。我仍然是列表页面本身。
我的控制器
public ActionResult Index(int? page)
{
Provider providerList = new Provider();
DAL DataAccess = new DAL();
IList<Provider> providers = DataAccess.GetListofProviders();
int pageSize = 5;
int pageNumber = (page ?? 1);
return View(providers.ToPagedList(pageNumber,pageSize));
}
[HttpPut]
public ActionResult Edit(int id)
{
DAL dataAccess = new DAL();
Provider provider = dataAccess.GetASingleProvider(id);
return View(provider);
}
[HttpPost]
public ActionResult Delete(int id)
{
DAL DataAccess = new DAL();
DataAccess.DeleteProvider(id);
return RedirectToAction("Index");
}
我的 JS 脚本用于删除和编辑
self.Delete = function (Provider) {
if (confirm('Are you sure you want to delete this row?')) {
$.ajax({
url: "/Provider/Delete/" + Provider.ProviderID(),
cache: false,
type: 'POST',
async: false,
contentType: 'application/json; charset=utf-8',
data: ko.toJSON(Provider.ProviderID()),
success: function (data) {
self.Providers.remove(Provider);
}
}).fail(
function (xhr, textStatus, err) {
alert(err);
});
}
}
self.update = function (Provider) {
$.ajax({
url: "/Provider/Edit/"+ Provider.ProviderID(),
cache: false,
type: 'PUT',
contentType: 'application/json; charset=utf-8',
data: ko.toJSON(Provider),
success: function (data) {
//alert(data);
self.Providers.removeAll();
self.Providers(data);
self.Provider(null);
}
})
.fail(
function (xhr, textStatus, err) {
alert(err);
};
}
编辑页面
<head>
<title>EDIT PROVIDER</title>
</head>
<body>
<div class="container">
<h1 class="col-sm-offset-2">Edit Provider Details:</h1><br />
<form class="form-horizontal" role="form" id="ProviderDetailsForm">
<div class="form-group">
<label class="col-sm-2 control-label labelfont">FIRST NAME:</label>
<div class="col-sm-6">
<input type="text" class="form-control" autofocus="autofocus" placeholder="Enter the First Name" id="FirstName" data-bind="value:FirstName" onkeypress="return onlyAlphabets(event);">
</div>
<label class="col-sm-4 labelfont errorMsg" id="Err_FirstName">Enter the first name</label>
</div>
<div class="form-group">
<label class="col-sm-2 control-label labelfont">CERTIFICATION:</label>
<div class="col-sm-6">
<select class="form-control" id="Certification" data-bind="value:SelectedCertification,options:Certification, optionsCaption: 'Select a Certification'">
</select>
</div>
<label class="col-sm-4 labelfont errorMsg" id="Err_Certification">Choose a Certificaton</label>
</div>
<div class="form-group">
<label class="col-sm-2 control-label labelfont">SPECIALIZATION:</label>
<div class="col-sm-6">
<select class="form-control" id="Specialization" data-bind="value:Specialization">
<option>Select a Specialization</option>
</select>
</div>
<label class="col-sm-4 labelfont errorMsg" id="Err_Specialization">Choose a Specialization</label>
</div>
<div class="form-group">
<label class="col-sm-2 control-label labelfont">TAXONOMY CODE:</label>
<div class="col-sm-6">
<input type="text" class="form-control" placeholder="Taxonomy code" id="TaxonomyCode" data-bind="textInput:TaxonomyCode,valueUpdate:'blur'">
</div>
</div>
<div class="form-group">
<button type="button" id="Update" class="btn btn-primary col-sm-1 col-sm-offset-4">Update</button>
<button type="reset" class="btn btn-primary col-sm-1">Reset</button>
</div>
</form>
</div>
<script type="text/javascript" src="../../Scripts/Create_Script.js"></script>
提供程序视图模型。
var Provider =
{
ProviderID: ko.observable(""),
FirstName: ko.observable(""),
LastName: ko.observable(""),
Certification: ko.observableArray(["M.B.B.S", "M.D.", "R.N.", "M.S.N."]),
SelectedCertification: ko.observable(""),
Specialization: ko.observable(""),
TaxonomyCode:ko.observable(""),
SSN: ko.observable(""),
ContactNumber: ko.observable(""),
ContactEmail: ko.observable(""),
FacilityName: ko.observable(""),
}
ko.applyBindings(Provider);
对不起长帖子的人。但是,我在Stackoverflow以及其他网站上搜索了很多关于这个问题的信息,但无法找到正确的答案。请在这里指导新手。多谢。
已编辑以添加列表页的 HTML。
@using PagedList;
@using PagedList.Mvc;
@model IPagedList<DEMO_JAN14.Models.Provider>
<head>
<title>LIST OF PROVIDERS</title>
</head>
<body>
<div class="container">
<h1>Providers List</h1><br/>
<a class="btn btn-primary col-sm-1" href="/Provider/Create">Create</a><br/>
<table class="table table-bordered" id="tblData">
<tr>
<th>First Name</th>
<th>Last Name</th>
<th>Certification</th>
<th>Specialization</th>
<th>Taxonomy Code</th>
<th>SSN</th>
<th>Facility Name</th>
<th>Contact No</th>
<th>Contact Email</th>
</tr>
<tbody data-bind="foreach:viewModel.DataList">
<tr>
<td class="col-lg-2" data-bind="text: FirstName"></td>
<td class="col-lg-2" data-bind="text: LastName"></td>
<td class="col-lg-2" data-bind="text: Certification"></td>
<td class="col-lg-2" data-bind="text: Specialization"></td>
<td class="col-lg-2" data-bind="text: TaxonomyCode"></td>
<td class="col-lg-2" data-bind="text: SSN"></td>
<td class="col-lg-2" data-bind="text: FacilityName"></td>
<td class="col-lg-2" data-bind="text: ContactNumber"></td>
<td class="col-lg-2" data-bind="text: ContactEmail"></td>
<td><button type="button" id="Edit" class="btn btn-primary" data-bind="click:$root.update">Edit</button></td>
<td><button type="button" id="Delete" class="btn btn-primary" data-bind="click:$root.Delete">Delete</button></td>
</tr>
</tbody>
</table>
Page @(Model.PageCount<Model.PageNumber? 0 : Model.PageNumber) of @Model.PageCount
@Html.PagedListPager( Model, page => Url.Action("Index", new { page }) )
</div>
</body>
<script type="text/javascript" src="../../Scripts/knockout.mapping-latest.js"></script>
<script type="text/javascript" src="~/Scripts/Index.js"></script>
<script type="text/javascript">
var data = @Html.Raw(Json.Encode(Model));
</script>
您遇到的第一个问题(删除),您必须将提供程序设置为可观察数组,如下所示:
self.Provider =ko.observableArray(
{
ProviderID: ko.observable(""),
FirstName: ko.observable(""),
LastName: ko.observable(""),
Certification: ko.observableArray(["M.B.B.S", "M.D.", "R.N.", "M.S.N."]),
SelectedCertification: ko.observable(""),
Specialization: ko.observable(""),
TaxonomyCode:ko.observable(""),
SSN: ko.observable(""),
ContactNumber: ko.observable(""),
ContactEmail: ko.observable(""),
FacilityName: ko.observable(""),
})
关于第二个问题,请尝试在 ajax 调用中将异步选项设置为 false,如果它不起作用,请尝试使用 JavaScript 重定向到该页面
相关文章:
- 将Javascript数组发送到控制器ASP.NET MVC
- 什么'是在asp.net MVC中将本地化的resources.resx文件转换为javascript文件的有效
- C#asp.net mvc Set CheckBoxFor已检查的具有Model Value的属性
- ASP.NET MVC 3-在ajax调用后,重定向到新页面或生成页面刷新
- 在创建视图mvc.net的过程中使用javascript
- MVC.Net 4 Razor问题使用<文本>标签
- 将文件异步上传到 MVC.NET
- 无论如何 MVC.Net Cdn 调用回退
- 如何加快从Angular/Mvc.net加载图像的速度
- 如何使用角度模块“ui-route”在指令中查找模板URL,而不会在MVC .NET上出现错误
- 将MVC.NET Razor与Javascript结合起来构建一个数组
- MVC.NET提示用户登录
- 从mvc.net获取用于AngularJS http的url的健壮方法是什么?
- MVC.net 3 -可维护的,重构友好的Javascript文件
- 在c#代码MVC . net中检索html中的id元素
- MVC.NET中引导日期拾取器的问题
- MVC . net 4.6询问用户是否想要运行JS文件
- 要求在MVC . net中加载竞速问题
- asp.net mvc - .NET MVC:查找默认的 Bootsrap JavaScript
- 在MVC.NET中使用html helper编辑模式