当前位置:  编程技术>.net/c#/asp.net

asp.net MVC进阶学习---HtmlHelper之GridView控件拓展(五)

    来源: 互联网  发布时间:2014-08-30

    本文导语:  在网上看到的一个不错的asp.net MVC学习系列,希望可以帮助那些正在研究MVC的朋友们。 本部分内容:asp.net MVC进阶学习---HtmlHelper之GridView控件拓展(五) 。 1.GridView使用Action代码   代码如下: public ActionResult Index()           {...

在网上看到的一个不错的asp.net MVC学习系列,希望可以帮助那些正在研究MVC的朋友们。
本部分内容:asp.net MVC进阶学习---HtmlHelper之GridView控件拓展(五) 。

1.GridView使用Action代码
 

代码如下:
public ActionResult Index()
          {
              CommonPage page = TempData["page"] as CommonPage;
              if (page == null)
              {
                  page = new CommonPage();
              }
              page.Total = context.Tab_Comment.Count();
              page.PageIndex = 1;
             page.PageSize = 10;
             page.PageCount = page.Total % page.PageSize == 0 ? page.Total / page.PageSize : page.Total / page.PageSize + 1;
             IEnumerable items = context.Tab_Comment.Skip((page.PageIndex-1) * page.PageSize).Take(page.PageSize).Select(c=>c);
             ViewData["items"] = new PageList(items,page,null,"ID","Home","List");
             TempData["page"] = page;
             return View();
         }
 
         public ActionResult List(int pageIndex)
         {
             CommonPage page = TempData["page"] as CommonPage;
             page.PageIndex = pageIndex;
             if (pageIndex = page.PageCount)
             {
                 page.PageIndex = page.PageCount;
             }
             IEnumerable items = context.Tab_Comment.Skip((page.PageIndex - 1) * page.PageSize).Take(page.PageSize).Select(c => c);
             ViewData["items"] = new PageList(items, page, null, "ID","Home","List");
             TempData["page"] = page;
             return View("Index");
         }
 
         public ActionResult Delete(int id)
         {
             context.Tab_Comment.DeleteOnSubmit(context.Tab_Comment.Single(c=>c.ID==id));
             context.SubmitChanges();
             return RedirectToAction("Index");
         }
 
         public ActionResult Update(Tab_Comment comment)
         {
             return RedirectToAction("Index");
         }
 

    上述代码主要是在GridView的使用中配合使用的Action,这是是在开发这个标签的时候做测试的Action代码,使用Linq与数据库交互。Index这个初始化页面,显示数据集合的第一页,并初始化数据分页的一些基本信息。List则主要适用于分页的,这里和Index中有重复的代码,这里只是做测试没有进行代码优化。数据的分页都由这个action来处理。Delete 这是来用于删除数据行的.Update 是用于编辑修改数据,这里方法的实现其实并没有实现修改,但是已经获得了提交修改的数据值,稍作处理就可以了。

2.页面使用标签
 

代码如下:

   

这个不用多少,应该都知道。这就是我们最终使用GridView 的时候的代码,看似有些繁琐了,特别是参数,有兴趣的可以进行优化。

3.编辑按钮的实现
 

代码如下:


        .Edit_Link
        {
        }
   
   
   
        var text = null;
        $(document).ready(function() {
            $("a.Edit_Link").click(function() {
                return Edit(this);
            })
        });

        //编辑
        function Edit(objEdit) {
            var tr = $(objEdit).parent().parent();
            text = $(tr).html();
            $(tr).children().each(function(i, obj) {
                var value = $(obj).text();
                var html = "";
                if (i < $(tr).children().length - 1) {
                    //隐藏表单域的id
                    if (i == 0) {
                        var id = $($(obj).children().get(0)).attr("id");
                        var hidden = $("#form0").find("#" + id);
                        if($(hidden).length > 0)
                        {
                            $("#form0 input[type=hidden][id=" + id + "]").val($($(obj).children().get(0)).attr("value"));
                        }
                        else
                        {
                            $("#form0").append("");
                        }
                    }

                    var trFirst = $(tr).parent().children().get(0);
                   
                    var columnName = $($(trFirst).children().get(i)).attr("id");
                    $("#form0 input[type=hidden][id=" + columnName + "]").val(value)
                    html = "";
                    $(obj).html(html);
                    $("#txt" + columnName).change(function() {
                        $("#form0 input[type=hidden][id=" + columnName + "]").val($(this).val());
                    });
                }
                else {
                    html = "更新   取消";
                    $(obj).html(html);
                    $("#btnCancel").click(function() {
                        Cancel(this);
                    });
                    $("#btnUpdate").click(function(){
                        alert($("#form0 input[type=hidden][id=ComUser]").val());
                        document.getElementById("form0").submit();
                    });
                }
            });
            $("a.Edit_Link").unbind("click");
            return false;
        }

        //取消
        function Cancel(objEdit) {
            var tr = $(objEdit).parent().parent();
            $(tr).html(text);
            $("a.Edit_Link").bind("click", function() {
                Edit(this);
            });
            return false;
        }

        //更新
        function Update(objUpdate) {

        }
   

    应该都知道MVC和Jquery的结合非常默契,我也是对Jquery情有独钟,要实现一些效果的变换Jquery再好不过了。至于这点写什么我也自己也不知道,原理就是将原来的编辑行中每个单元格的数据替换成 然将数据值赋给这个文本框,编辑按钮则变为相应的更新按钮。然后修改文本框中的数据会自动填充到生成的表单中对应的隐藏域中去。然后用js实现表单提交就OK了。

    到此该写的都马马虎虎的写完了,略有成就感,写了好几篇啊。这个控件虽然写出来了,但是还是有很多地方有待优化,不过在使用的过程中已经方便了不少,特别是页面的代码,不用foreach 去循环了。当我把这个控件写出来的时候,我发现我这个.net程序员彻彻底底的爱上了MVC,呵呵,扩展性比WebForm要好很多,用MVC也做过不少东西了,以前都是简简单单没有去追求,没有去思考它的原理。MVC就是一种模式,我们可以不用拘泥他们的微软的那种格式,我们可以彻底的改变他们的目录结构,根据自己的需要来设置个性化目录。这里不再多少,以后再写。这个控件有待改善的地方还有很多,功能是都实现了,还有细节等等都有待优化。

    原文作者:情缘 http://www.cnblogs.com/qingyuan


    
 
 

您可能感兴趣的文章:

  • asp.net MVC进阶学习---HtmlHelper之GridView控件拓展(一)
  • asp.net MVC进阶学习---个性化目录结构(二)
  • asp.net MVC进阶学习---HtmlHelper控件解析(五)
  • asp.net MVC进阶学习---HtmlHelper控件解析(四)
  • asp.net MVC进阶学习---个性化目录结构(一)
  • asp.net MVC进阶学习---HtmlHelper控件解析(三)
  • asp.net MVC进阶学习---HtmlHelper控件解析(一)
  • asp.net MVC进阶学习---HtmlHelper控件解析(二)
  • asp.net MVC进阶学习---HtmlHelper之GridView控件拓展(二)
  • asp.net MVC进阶学习---个性化目录结构(三)
  • asp.net MVC进阶学习---HtmlHelper之GridView控件拓展(四)
  • asp.net MVC进阶学习---HtmlHelper之GridView控件拓展(三)
  • asp.net MVC进阶学习---View和Controller之间的数据传递(一)
  • asp.net Control控件常用的属性与方法
  • ASP.NET 页面中加添加用户控件的写法
  • asp.net Google样式分页控件用法
  • Asp.net日历控件显示年和月
  • asp控件和html控件的概念区别
  • Asp.Net其他页面如何调用Web用户控件写的分页
  • asp.net动态添加非标准html控件的方法
  • asp.net 用户控件中图片与样式引用的问题
  • asp.net MVC进阶学习---HtmlHelper控件解析(三) iis7站长之家
  • 把某个asp.net 控件替换成自定义控件的方法
  • asp.net Textbox服务器控件的技巧分享(图文)
  • asp.net(c#版)添加DataRow数据列到DataTable控件
  • asp.net 动态创建控件的演示实例
  • asp.net服务器控件调整技巧
  • asp.net实例代码 在DataGrid控件中显示数据
  • asp.net Textbox服务器控件的例子
  • 学习asp.net动态添加控件的方法
  • asp.net 动态添加多个用户控件(实例代码)
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • ASP.NET之 Ajax相关知识介绍及组件图
  • 我想了解一些关于Java怎样与Asp或Asp.net结合方面在未来发展方向的问题?
  • c#/ASP.NET操作cookie(读写)代码示例
  • asp.net UrlEncode对应asp urlencode的处理方法
  • asp.net实例 定义和使用asp:AccessDataSource
  • win2008 r2 服务器环境配置(FTP/ASP/ASP.Net/PHP)
  • asp与asp.net的session共享
  • 如何在unix下发布asp?
  • 怎么让Apache支持Asp?
  • ??谁能把ASP代码改为JSP的
  • Linux平台下哪种方法实现ASP好?
  • ASP和ASP.Net共享Session解决办法
  • 通过socket和asp打交道
  • 犹豫中……,到底是选择ASP,还是JSP?
  • asp 是否 可用applet标签?帮忙!!
  • asp.net判断数据库表是否存在 asp.net修改表名的方法
  • 新人提问:asp+access的程序在linux下怎么改?
  • 用JAVA APPLET做的交互式网页和ASP、PHP做的相比有什么优势呢?
  • asp.net文字水印功能简单代码
  • asp里面可否使用java写的邮件,给30分.
  • asp与Jsp可否在iis中共存的问题


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3