我和小美的撸码日记(2)之第一个基于MVC+Jqgrid的列表页面

一、前言

“尼玛哥,上周你教我改了下OA系统UI,黄总看了很满意呀。”
    “不错不错,看来小美进步很大,可以提前结束试用期,到时候加工资别忘了请我吃饭呀!”
    “尼玛哥,你有女朋友了吗?”

“小美,这样不好吧,虽然我很优秀,你也很不错,但是我不是因为对你有企图才教你写程序呀!当然你执意要这样的话,我也只好从了你啦。”

“尼玛哥,你老人家想多了,我只是想告诉你,像你这么小气还让女孩子请吃饭,能交到女朋友才怪。对啦,我们OA系统以前是.net WebForm的,里面的表格都是gridview的,MVC里我都没找到,这个怎么办呀?”

“嗯,gridview是个服务器控制,没办法直接在视图里面用,而且用服务器控件用户体验也不好,这次教你个新玩意儿,用jqgrid吧。jqgrid是个js开源的表格插件,轻量级,好控制,效果也很不错。给你看下官网和我在其它项目中的使用效果”

Jqgrid官网: http://www.trirand.com/blog/

“尼玛哥,搞什么鬼呀,本来很好看的界面,你打什么马塞克呀,你不知道马塞克严重影响到了人类的进步吗?”

“小美,不要在意这些细节,博客园是大家学习知识的地方,所以呢我把有关公司的一些东西打了点码。重点是在于和大家一起学技术,你看人家Teacher苍,哪部电影没打码,人家不照样红。”

二、Jqgrid在MVC中的使用

“尼玛哥,jqgrid是个js插件,要怎么样才以跟MVC结合起来使用呢?”

“小美,光说你可能不理解,我来举个栗子,教你做一项基础资料,做个‘部门管理’,然后一步步跟你来讲我是怎么把jqgrid插到你的MVC中去的。”

“用Jqgrid来展示数据其实很简单,引入这个插件以后,我们只需塞给它一个Json数据包,马上一个漂亮的数据列表就可以展现在我们面前。"

“尼玛哥,我昨天查了下MVC,它其实就是model、View、Control,model是实体,View是来显示数据的,Control主要控制前后台的交互;那这个Jqgrid插件应该就是放在View上的吧。”

“聪明,本来我还想着怎么来跟你解释下,你自己先预习了,不错呀,小美。好了,前戏来过了,我们正式开撸吧。”

“尼玛哥,Model我直接用代码生成器给生成了,然后我觉得控制器应该是从后台取到部门列表,然后转换成Json传给前台,代码仿照你上次教我写菜单Json那样写的,你看看可以不。”

/// <summary>
    /// 部门管理控制器
    /// </summary>
    public class DepartmentController : PublicController<Base_Department>
    {
        Base_DepartmentBll base_departmentbll = new Base_DepartmentBll();
        /// <summary>
        /// 【部门管理】返回列表JONS
        /// </summary>
        /// <returns></returns>
        public ActionResult GridListJson(JqGridParam jqgridparam)
        {
            DataTable ListData = base_departmentbll.GetList(ref jqgridparam);
            return Content(ListData.ToJson());
        }
    }

    /// <summary>
    /// 部门管理
    /// <author>
    ///        <name>she</name>
    ///        <date>2014.08.07 12:34</date>
    /// </author>
    /// </summary>
    public class Base_DepartmentBll : RepositoryFactory<Base_Department>
    {
            /// <summary>
        /// 获取部门 列表
        /// </summary>
        /// <param name="jqgridparam"></param>
        /// <returns></returns>
        public DataTable GetList( ref JqGridParam jqgridparam)
        {
            StringBuilder strSql = new StringBuilder();
            strSql.Append(@"SELECT  *
                            FROM    ( SELECT    d.DepartmentId ,            --主键
                                                c.FullName AS CompanyName ,    --所属公司
                                                d.CompanyId ,                --所属公司Id
                                                d.Code ,                    --编码
                                                d.FullName ,                --部门名称
                                                d.ShortName ,                --部门简称
                                                d.Nature ,                    --部门性质
                                                d.Manager ,                    --负责人
                                                d.Phone ,                    --电话
                                                d.Fax ,                        --传真
                                                d.Enabled ,                    --有效
                                                d.SortCode,                 --排序吗
                                                d.Remark                    --说明
                                      FROM      Base_Department d
                                                LEFT JOIN Base_Company c ON c.CompanyId = d.CompanyId
                                    ) T WHERE 1=1 ");
            List<DbParameter> parameter = new List<DbParameter>();
            return Repository().FindTablePageBySql(strSql.ToString(), parameter.ToArray(), ref jqgridparam);
            return Repository().FindTableBySql(strSql.ToString(), parameter.ToArray());
        }
    }

“不错呀,学习能力很强,小美你这点很像我呀!”
   “尼玛哥,那个GetList函数里有个 ref JqGridParam jqgridparam参数,我是照抄过来的,那个参数有什么用呢?”

“小美,你看下最后调的那个方法FindTablePageBySql,里面都有Page这单词,明显是分页用的。还有了,你现在也能看懂不少代码了,遇到这类公用方法别光知道调用,自己也F12跳进去看看,对你学开发很有帮助呀。”

“好了,View层的代码我来教你写,其实我也是从官方Demo那里学的。以后你也别光看日语电影了,欧美系列的也看看,以后就能看懂英文文档,对你提高技术有帮助的。”

@{
    ViewBag.Title = "部门管理";
}
<!--框架必需start-->
<link href="~/Content/Styles/learunui-framework.css" rel="stylesheet" />
<script src="~/Content/Scripts/jquery/jquery-1.8.2.min.js"></script>
<script src="~/Content/Scripts/learunui-framework.js"></script>
<!--框架必需end-->
<!--jqgrid表格组件start-->
<script src="~/Content/Scripts/jqgrid/jquery-ui-custom.min.js"></script>
<script src="~/Content/Scripts/jqgrid/grid.locale-cn.js"></script>
<link href="~/Content/Scripts/jqgrid/css/jqgrid.css" rel="stylesheet" />
<script src="~/Content/Scripts/jqgrid/jqGrid.js"></script>
<!--表格组件end-->
<link href="~/Content/Scripts/tree/tree.css" rel="stylesheet" />
<script src="~/Content/Scripts/tree/tree.js"></script>
<script type="text/javascript">
    $(document).ready(function () {
        GetGrid("");
    });
    //加载表格
    function GetGrid(CompanyId) {
        $("#gridTable").jqGrid({
            url: "/Department/GridListJson",
            datatype: "json",
            height: $(window).height() - 105,
            autowidth: true,
            colModel: [
                { label: ‘主键‘, name: ‘departmentid‘, index: "departmentid", hidden: true },
                { label: ‘编码‘, name: ‘code‘, index: "code", width: 80 },
                { label: ‘部门‘, name: ‘fullname‘, index: "fullname", width: 100 },
                { label: ‘简称‘, name: ‘shortname‘, index: "shortname", width: 100 },
                { label: ‘性质‘, name: ‘nature‘, index: "nature", width: 100, align: "center" },
                { label: ‘负责人‘, name: ‘manager‘, index: "manager", width: 80, align: "center" },
                { label: ‘电话‘, name: ‘phone‘, index: "phone", width: 100, align: "center" },
                { label: ‘传真‘, name: ‘fax‘, index: "fax", width: 100, align: "center" },
                { label: ‘所属公司‘, name: ‘companyname‘, index: "companyname", width: 120 },
                {
                    label: ‘有效‘, name: ‘enabled‘, index: ‘enabled‘, width: 45, align: ‘center‘,
                    formatter: function (cellvalue, options, rowObject) {
                        if (cellvalue == ‘1‘) return "<img src=‘/Content/Images/checkokmark.gif‘/>";
                        if (cellvalue == ‘0‘) return "<img src=‘/Content/Images/checknomark.gif‘/>";
                    }
                },
                { label: ‘说明‘, name: ‘remark‘, index: "remark", width: 300 }
            ],
            pager: "#gridPager",
            sortname: ‘SortCode‘,
            sortorder: ‘asc‘,
            rownumbers: true,
            shrinkToFit: false,
            gridview: true,
        });
    }
</script>
<div id="layout" class="layout">
    <div class="layoutPanel layout-center">
        <div class="btnbartitle">
            <div>
                部门列表<span id="CenterTitle"></span>
            </div>
        </div>
        <table id="gridTable"></table>
        <div id="gridPager"></div>
    </div>
</div>

“尼玛哥,你以前跟我讲前后台交互要用AV技术的,这边怎么就没看到Ajax调用的痕迹呢?”

“小美,你又傻了吧,你看羞羞小电影的时候难道还在办公室这种公司场所看,肯定是找个地方躲起来偷偷看,Jqgrid是个插件,它当然是封装了一下,你看那里有个URL参数,我把它指向你控制器里获取Json的Action,这样Jqgrid就能获得返回的Json了。”

“哦,原来是他们封装了东西,那gridPager这个分页的东西,肯定也是后台封装了东西,不然根本跟列表联系不上。”

“对,小美很聪明,这东西是开源的,有时间你也去看一下,对你以后用这插件也会有帮助的,源码还是放百度网盘的,你自己去下。”

源码下载地址:http://pan.baidu.com/s/1gdiVKJp

“尼玛哥,你给我的源码里怎么跟上面的图片有点不一样,左侧的公司树怎么不见了?工具栏也没有。”

“小美,我都跟你说了,一步步,慢慢来,你先把这个表格弄好了,下周再教你剩下的。”

时间: 2024-08-04 13:00:19

我和小美的撸码日记(2)之第一个基于MVC+Jqgrid的列表页面的相关文章

我和小美的撸码日记(3)之一句话搞定MVC表单页数据绑定与提交

另外献上在<线体验Demo地址>希望大家也能从中得到一些启发. 地址:http://121.40.148.178:8080/ . 用户名:guest,密码:123456 QQ技术交流群:239168429 "尼玛哥,你今天有空么?" "今天周日呀,怎么会没空,你这是要约么?麻辣烫凉皮我都吃,在哪儿,我一会儿就到." "约你妹呀,我昨天都加一天班了,东西到现在还没搞完,你给我快点过来呀,我需要你!" "别急噢,有哥在,这都不叫

我和小美的撸码日记--基于MVC+Jqgrid的.Net快速开发框架

前言:以前的帐号没有发首页的权限,特此把这篇文章从另外一个博客移过来,这篇是<我和小美的撸码日记>的序 一转眼务农6年了,呆过大公司也去过小作坊,码农的人生除了抠腚还是抠腚.在所有呆过的公司里,感觉项目没有不延期的,真的是因为自己不努力吗?也没有呀!上班不怎么聊QQ回家也很少看动作片,还搞过几次通宵撸码的. 以前总感觉是项目经理把工时估少了,后来自己也做过项目管理,按照以往的经历估工时,做到最后还是会有些延期,要不就是加班拼命赶.我发现在项目中总是会遇到一些这样那样的问题,比如:客户需求变了,

听风讲MVC丶 —— 一言不合就撸码 (未完待续&#183;&#183;&#183;&#183;&#183;&#183;)

     希望你看了此小随 可以实现自己的MVC框架     也祝所有的程序员身体健康一切安好                                                                                                                                                ——久伴深海丶默 1.什么是前端控制器(font controller).Java Web中的前端控制器是应用的门面,

前端上路第三弹-正式撸码

又过了几个月没更新了,话说要当一名又撸码又撰文的FEer,真的挺难的,没那文学细胞,写不出多华丽的辞藻,每次写起来都像记流水账,不过记录自己的前端之路,不就是一步一步走过来的吗. 好了,废话不多说,上一篇讲解了如何利用markman对psd文件进行标注,接下来,万事俱备,只欠撸码咯~ ,这就是上次标注完成的图,但是我的习惯是当拿到标注完成的图时,并不会立即开始编写,我的习惯是想想具体的布局,然后看看有没有什么特别难实现的地方,正所谓磨刀不误砍柴工嘛. 对于这个效果图,我的想法分成上下两个部分,如

响应国家号召,在家撸码之React迁移记

最近这段时间新型冠状病毒肆虐,上海确诊人数每天都在增加,人人提心吊胆,街上都没人了.为了响应国家号召,近期呆在家里撸码,着手将项目迁移到React中,项目比较朴素,是一张线索提交页面,包含表单.图片滚动等功能. 一.目录结构 项目基于Create React App构建而成,简单的做了下二次封装,src目录的结构如下所示. ├── src │ ├── __tests__ ---------------------- 测试文件 │ ├── common ----------------------

《 无码的青春 》 第一章 又逢情人节

<thinking in java>多线程这一节还没翻几页,手机铃声又一次响起. 刚接通,那边响起了一个熟悉的声音,"东方,晚上出来陪我吃饭吧". 一点都不用犹豫,就知道是沈思雨的声音. "奥,,今天,今天,,,",我还没说完,那边的声音就又响起. "室友都出去约会了,,我,,不想一个人.你,今天不用约会吧.". "奥,不用,不用的,,,". "那好,五点半水游城门口见." "恩,好的

内核源码分析之进程地址空间(基于3.16-rc4)

所谓进程的地址空间,指的就是进程的虚拟地址空间.当创建一个进程时,内核会为该进程分配一个线性的地址空间(虚拟地址空间),有了虚拟地址空间后,内核就可以通过页表将进程的物理地址地址空间映射到其虚拟地址空间中,程序员所能看到的其实都是虚拟地址,物理地址对程序员而言是透明的.当程序运行时,MMU硬件机制会将程序中的虚拟地址转换成物理地址,然后在内存中找到指令和数据,来执行进程的代码.下面我们就来分析和进程的地址空间相关的各种数据结构和操作. 用到的数据结构: 1.内存描述符struct mm_stru

快速开发:我和实习妹纸的撸码故事(1)

曾经六六我也是一个初级开发的实习生,当年的我初入农田,一心要做一个高产量高品质的码农,做码农界的袁隆平!然而,现实总是无比的残酷,我一个刚入门的码农,刚进农田就跌了许多跟头.BUG天天困扰着我,不过这也是一种磨练.不然我六六也难以成为一个合格的码农! 不过现在时代不同了,软件公司越来越多,软件开发行业的竞争越来越激烈了.公司越来越看重成本和效率.所以很多公司都不愿意招聘毫无经验的初级码农.项目进度跟不上,我们公司的码农数量又迟迟补充不上.不用想,领导对应届大学生能力有质疑也是正常的,但是高技术的

web前端 | 如何选择撸码神器

进来,不少小伙子.小妹子来问一个家常便饭,但又逃不脱的问题: 小北哥哥,现在这么多编辑器,我该用哪一个好啊,看着都不孬啊(孬字用得好!) 此篇文章,纯客观分析 顺便吹逼,老鸟和大神直接略过吧!省的你们看到我写这个问题,再说我烦不烦啊,这问题都讨论了多少年了,甚至好多群里,一看到谁在讨论编辑器,就要送飞机票. 但很多转入前端的孩子还是很迷茫, 能力和悟性也分三六九等,人不同,自然适合自己的工具也要不同, 你不能你是个弱鸡,就学人家用VIM 或者直接文本编辑器?你这不找虐呢? 俗话说得好: 工欲善其