zoukankan      html  css  js  c++  java
  • MVC3+EF5.0 code first+Flexigrid+ajax请求+jquery dialog 增删改查

    MVC3+EF5.0 code first+Flexigrid+ajax请求+jquery dialog 增删改查

    本文的目的:

     
      1、MVC3项目简单配置EF code first生成并初始化数据库。
      2、利用flexigrid展示并使用ajax展示数据,支持显示列增减,显示列排序,显示列模糊查询,熟悉表格控件的使用。
      3、利用jquery ajax请求实现增删查改
      4、利用jquery dialog弹出层实现添加,修改。
      5、扩展方法及表达式树构建lambda表达式

    项目截图说明

    附flexigrid参数说明(可以去flexigrid.js文件中查看配置):

    height: 200, //flexigrid插件的高度,单位为px
    'auto', //宽度值,auto表示根据每列的宽度自动计算,在IE6下建议设置具体值否则会有问题
    striped: true, //是否显示斑纹效果,默认是奇偶交互的形式
    novstripe: false,//没用过这个属性
    min 30, //列的最小宽度
    minheight: 80, //列的最小高度
    resizable: false, //resizable table是否可伸缩
    url: false, //ajax url,ajax方式对应的url地址
    method: 'POST', // data sending method,数据发送方式
    dataType: 'json', // type of data loaded,数据加载的类型,xml,json
    errormsg: '发生错误', //错误提升信息
    usepager: false, //是否分页
    nowrap: true, //是否不换行
    page: 1, //current page,默认当前页
    total: 1, //total pages,总页面数
    useRp: true, //use the results per page select box,是否可以动态设置每页显示的结果数
    rp: 25, // results per page,每页默认的结果数
    rpOptions: [10, 15, 20, 25, 40, 100], //可选择设定的每页结果数
    title: false, //是否包含标题
    pagestat: '显示记录从{from}到{to},总数 {total} 条', //显示当前页和总页面的样式
    procmsg: '正在处理数据,请稍候 ...', //正在处理的提示信息
    query: '', //搜索查询的条件
    qtype: '', //搜索查询的类别
    qop: "Eq", //搜索的操作符
    nomsg: '没有符合条件的记录存在', //无结果的提示信息
    minColToggle: 1, //允许显示的最小列数
    showToggleBtn: true, //是否允许显示隐藏列,该属性有bug设置成false点击头脚本报错。
    hideOnSubmit: true, //是否在回调时显示遮盖
    showTableToggleBtn: false, //是否显示【显示隐藏Grid】的按钮 
    autoload: true, //自动加载,即第一次发起ajax请求
    blockOpacity: 0.5, //透明度设置
    onToggleCol: false, //当在行之间转换时,可在此方法中重写默认实现,基本无用
    onChangeSort: false, //当改变排序时,可在此方法中重写默认实现,自行实现客户端排序
    onSuccess: false, //成功后执行
    onSubmit: false, // 调用自定义的计算函数,基本没用 

    实现步骤

    1、配置EF5.0 code first生成并初始化数据库

      首先在项目中添加对EF5.0的引用,获取方式可以通过nuget包管理器添加或者通过控制台添加,这里给出一种方式的截图。

    编写实体类(代码中有注释说明):

     View Code

    编写数据库上下文:

     View Code

    此处注意若是不指定数据库连接字符串名称,在web.config中只需将连接字符串的名称与数据库上下文类的名称一样即可。

    连接字符串:

    <connectionStrings>
        <add name="GridDbContext" connectionString="Data Source=(local);Initial Catalog=XXXX;Integrated Security=SSPI" providerName="System.Data.SqlClient" />
      </connectionStrings>

    编写数据库表初始化数据填充类:

     View Code

    至此,EF生成数据库配置完成,我们只需在controller中随便写一个方法调用一下,便可在数据库中自动生数据库及表,并初始化数据。

    2、配置Flexigrid

    在模板页中添加对jquery等js的引用

    <script src="../../Scripts/jquery-1.8.0.min.js" type="text/javascript"></script>
        <script src="../../Scripts/jquery-ui-1.8.23.min.js" type="text/javascript"></script>
        <script src="../../Scripts/jquery.unobtrusive-ajax.min.js" type="text/javascript"></script>
        <script src="@Url.Content("~/Scripts/flexigrid.js")" type="text/javascript"></script>
        <script src="@Url.Content("~/Scripts/flexigrid.pack.js")" type="text/javascript"></script>
        <link href="@Url.Content("~/Content/flexigrid.css")" rel="stylesheet" type="text/css" />

    首先我们在HomeController中为Index添加一个视图,在此视图中配置flxigrid。

    index页面显示代码:

     View Code

    flexigrid的配置说明参考前文给出的配置及js中的配置说明,下面给出重点几处的说明:

    $('#students').flexigrid()将指定表格转化成flexigrid控件

    url: '/Home/FlexigridList',后台返回表格ajax数据的方法,datatype为json数据类型

    colModel:配置显示列名称,后台返回对应的数据列,大小,是否排序,位置等

    buttons:工具栏按钮

    searchitems:设置需要查询的列

    其他配置不做说明(checkbox有问题。)

    配置完成以后,运行程序现在便能程序出flexigrid的样子了。

    接下来我们为根据某一显示列排序及模糊查询扩展两个IQueryable<T>的扩展方法,代码如下:

     View Code

    后台Home/FlexigridList获取数据的方法(代码中有详细说明)

     View Code

    此方法的重点在于去前台参数值,根据某一字段构建排序及模糊查询,返回前台需要的json数据等。

    文章到此为止,如果程序正确前台按自定列排序,查询,显示数据等都应该正常。

    3、实现增删改

    点击flexigrid的添加和修改按钮,通过jquery 的ajax请求,将添加及修改页面加载到jquery dialog中。demo中单独为此了一个 js函数,代码如下

    复制代码
            function AddOrEdit(ids) {
                $.ajax({
                    type: "GET",
                    url: "/home/AddStudent?id="+ids,
                    success: function (html) {
                        $("<div class='formtalbe'></div>").html(html)
                                    .attr("title", "操作")
                                    .dialog({
                                        autoOpen: true,
                                        modal: true,
                                         300,
                                        buttons: {
                                            "确定": function () {
                                                $(".formtalbe").find("form").submit();
                                                $(".formtalbe").remove();
                                            },
                                            "取消": function () { $(this).dialog('destroy').remove(); $(this).dialog("close"); }
                                        }
                                    });
                    },
                    error: function () {
                        $(".formtalbe").remove();
                        alert("操作失败!");
                    }
                });
    
            }
    复制代码

    此方法的关键在于ajax请求后台aciton并将试图加载在一个jquery dialog中,jquery控制表单提交等,添加后修改判断通过实体类ID判断。

    后台添加修改方法:

    复制代码
    //添加及修改
            public ActionResult AddStudent(int id=0)
            {
                var stu=id>0?db.Students.Find(id):new Student();
                return View(stu);
            }
            [HttpPost]
            public ActionResult AddStudent(Student student,FormCollection fc)
            {
                TryUpdateModel(student, fc);
                if (student.ID == 0)
                    db.Students.Add(student);
                else
                    db.Entry(student).State = EntityState.Modified;
                db.SaveChanges();
                return RedirectToAction("Index");
            }
    复制代码

    添加及修改页面:

     View Code

    前台删除js方法,同样是ajax提交

    复制代码
    function DeletStudent(idsstring) {
                $.getJSON("/Home/DelStudent?ids=" + idsstring, function (data) {
                    if (data == true)
                        alert("删除成功!");
                });
            }
    复制代码

    后台action方法

    复制代码
    //批量删除
            public ActionResult DelStudent(string ids)
            {
                var idarray = ids.Split(',');
                foreach(var id in idarray)
                {
                    var temp=db.Students.Find(int.Parse(id));
                    db.Entry(temp).State=EntityState.Deleted;
                }
                db.SaveChanges();
                return Json(true);
            }
    复制代码

    案例到此结束,flexigrid展示数据,数据的增删改查都已经实现了。

    结语

    由于只是为了掩饰flexigrid的使用,项目中有很多不合理的地方,已知的问题:flexigrid多选框的问题,添加修改字段没有添加验证,添加修改及删除成功后没有实现局部刷新等问题。

    如有需要可自己扩展。

     DEMO下载:点我下载

    欢迎各位有志之士讨论批评,如资料有用欢迎推荐,欢迎拍砖。

  • 相关阅读:
    @configuration 和 @bean
    js中关键字 const , let , var 的用法区别
    springboot+vue项目demo地址
    快速开发框架下载地址(github)
    搭建vue项目并启动vue项目
    export default{} 和 new Vue()都是什么意思
    反向代理
    [转]python类方法
    linux中waitpid及wait的用法
    mount
  • 原文地址:https://www.cnblogs.com/Leo_wl/p/3229892.html
Copyright © 2011-2022 走看看