MVC3学习:利用mvc3+ajax实现删除记录
2024-10-16 20:19:16
首先根据模板生成list视图,上面就会有一个delete的链接,但是模板自带的这种删除,需要另外再打开一个删除页,再进行删除。我们可以利用ajax来改写,实现在当前页删除。
在视图上面,将原来的
@Html.ActionLink("Delete", "Delete", new { id=item.Uid })
改为
<a href="#" name="delete" id="@item.Uid">Delete</a>
接着编写JQuery ajax
<script type="text/javascript">
$(function () {
$("[name='delete']").click(function () {
if (confirm("确定要删除此记录?")) {
var Uid = $(this).attr("id");
var tr = $(this).parent().parent();
$.post("delete", { id: Uid },
function (data) {
if (data == "-1") {
alert("删除失败");
return false;
}
else {
$(tr).remove();
alert("删除成功");
}
}
);
}
});
});
</script>
此处将参数id返回给方法delete进行处理,处理完成后将结果再返回回来。
因此,接着在控制器里面编写delete方法
public ActionResult delete(int id)
{
try
{
if (Request.IsAjaxRequest())
{ Users u = db.Users.Find(id);
db.Users.Remove(u);
int n = db.SaveChanges();
return Content(n.ToString());
}
return Content("-1");
}
catch
{
return View();
}
}
我用的EF code first的删除记录方法。先根据find(id)找到此行记录,然后调用remove删除。
注意此处的参数名为id,必须要和ajax里面返回的参数名id一样。要用Request.IsAjaxRequest()来判断是否使用ajax处理数据。
最新文章
- pitch yaw roll是什么
- <;总结>;delphi WebBrowser控件的使用中出现的bug
- Debian 8.2 下安装MySQL5.7.9 Generic Binaries
- Entityframework 事务
- iOS - UI - UIPageControl
- [转]WINDOW进程间数据通讯以及共享内存
- Area of Simple Polygons
- centos上如何安装mysql
- datagrid直接编辑保存“设计缺陷”
- Ecstore安装篇-1.运行系统环境要求
- android 滑动分页
- [LeetCode] 21. 合并两个有序链表
- 0x16 Tire
- 蓝桥杯 历届试题 幸运数 dfs
- ionic ion-tab图标修改, 自定义tab图标
- MySQL:锁
- 自学Python2.10-跳出循环(break、continue)
- Android 之窗口小部件高级篇--App Widget 之 RemoteViews
- 关于线上js报错问题的思考
- Redis讲解