试图创建可编辑的表

时间:2013-09-26 19:57:49

标签: c# jquery

我目前有一个绑定到数据集的asp:gridview。我需要的是能够单击一个单元格并使其可编辑,然后当焦点丢失时,更新的字段将保存到数据库中。如果需要,我可以将代码从gridview更改为其他内容。该方法并不重要,只是最终结果。显示数据库数据的表格,允许对内联单元格进行编辑。如果可能的话,还需要能够将一些可编辑字段放入下拉列表中。任何人都可以帮助我,对现有插件或方法的任何建议如何做到这一点没有太多的复杂性?

由于

3 个答案:

答案 0 :(得分:0)

试试这个(双击打开一个可编辑的单元格):

$(document).ready(function(){
    var c = $(document);


    c.on("dblclick","td",function(){ 
        $(this).html("<input type='text' class='txtEdit' />");
    });

    c.on("focusout",".txtEdit",function(){
        var td = $(this).parent("td");
        td.html($(this).val());
    });
});

答案 1 :(得分:0)

如果您愿意,可以使用SlickGrid。 http://mleibman.github.io/SlickGrid/examples/example3-editing.html

或来自http://mrbool.com/how-to-create-an-editable-html-table-with-jquery/27425

的小javascript
$(function () {
    $("td").dblclick(function () {
        var OriginalContent = $(this).text();

        $(this).addClass("cellEditing");
        $(this).html("<input type='text' value='" + OriginalContent + "' />");
        $(this).children().first().focus();

        $(this).children().first().keypress(function (e) {
            if (e.which == 13) {
                var newContent = $(this).val();
                $(this).parent().text(newContent);
                $(this).parent().removeClass("cellEditing");
            }
        });

    $(this).children().first().blur(function(){
        $(this).parent().text(OriginalContent);
        $(this).parent().removeClass("cellEditing");
    });
    });
});


Read more: http://mrbool.com/how-to-create-an-editable-html-table-with-jquery/27425#ixzz2g24Rpq6t

答案 2 :(得分:0)

我为你在VS 2010做了解决方案。

http://www.fileconvoy.com/dfl.php?id=gf8df2b85b587e3c2999379985e0a4fcad2e7e3a74

主要思想是使用“数据”自定义您的网格(和网格元素)。在编辑完成时,将包含有关要在服务器端更新的字段和值的所有必要信息的属性。

当dinamically创建的输入失去焦点时,数据通过ajax(通过jQuery)发回服务器。

准备网格:

    protected void Page_Load(object sender, EventArgs e)
    {
        var ds = new[] { 
                            new { Id = 0, Name = "Joe" }, 
                            new { Id = 1, Name = "Nick" } 
                       };

        GridView1.RowDataBound += new GridViewRowEventHandler(GridView1_RowDataBound);
        GridView1.Attributes.Add("data-upd-route", "GridWorker.aspx");
        GridView1.DataSource = ds;
        GridView1.DataBind();
    }

    public void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        if (e.Row.RowType == DataControlRowType.DataRow)
        {
            e.Row.Attributes.Add("data-id", e.Row.DataItem.GetType().GetProperty("Id").GetValue(e.Row.DataItem, null).ToString());
            e.Row.Cells[1].Attributes.Add("data-col-name", "Name");
            e.Row.Cells[1].Attributes.Add("class", "bg-updatable");
        }
    }

jQuery处理客户端交互

function onGridCellInputBlur(event) {
    var target = $(event.target);

    if (target.val() == target.next().val()) {
        target.closest("td").html(target.next().val());
    }
    else {
        doBackgroundRequest(target);
    }
}

function doBackgroundRequest(descriptiveInitiator) {
var colName = descriptiveInitiator.closest("td").attr("data-col-name");
var colValue = descriptiveInitiator.val();
var entityId = descriptiveInitiator.closest("tr").attr("data-id");
var updRoute = descriptiveInitiator.closest("table").attr("data-upd-route");

$.ajax({
    url: updRoute + "?entityId=" + entityId + "&colName=" + colName + "&colValue=" + colValue,
    type: "POST",
    success: function(p1) {
        descriptiveInitiator.closest("td").html(descriptiveInitiator.val());
    },
    error: function (p1) {
        alert(p1.Message);
    }
    });
}

在服务器端发布后做一些工作

public partial class GridWorker : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        var entityId = Request.QueryString["entityId"];
        var colName = Request.QueryString["colName"];
        var colValue = Request.QueryString["colValue"];

        //TODO: do some work
    }
}