首页 > 其他 > 详细

Editable DataGrid 实现列表新增编辑功能

时间:2016-11-25 16:50:20      阅读:231      评论:0      收藏:0      [点我收藏+]
今天在开发一个功能时候,需要直接在列表实现新增、编辑等功能。于是查看easyui 相关文档,找到相关解决办法。
easyui的datagrid支持可编辑功能使用户能够数据网格中添加一个用户可以更新一个多个

 

下面是我在项目中的实现代码:
第一步:引用
      easyui.css
第二步:Html和Javascript代码
    <h2>Editable DataGrid Demo</h2>
    <div class="demo-info">
        <div class="demo-tip icon-tip">&nbsp;</div>
        <div>Click the edit button on the right side of row to start editing.</div>
    </div>
    
    <div style="margin:10px 0">
        <a href="javascript:void(0)" class="easyui-linkbutton" onclick="insert()">Insert Row</a>
    </div>
    
    <table id="tt"></table>
    
    <script>
        var products = [
            {productid:FI-SW-01,name:Koi},
            {productid:K9-DL-01,name:Dalmation},
            {productid:RP-SN-01,name:Rattlesnake},
            {productid:RP-LI-02,name:Iguana},
            {productid:FL-DSH-01,name:Manx},
            {productid:FL-DLH-02,name:Persian},
            {productid:AV-CB-01,name:Amazon Parrot}
        ];
        $(function(){
            $(#tt).datagrid({
                title:Editable DataGrid,
                iconCls:icon-edit,
                width:660,
                height:250,
                singleSelect:true,
                idField:itemid,
                url:data/datagrid_data.json,
                columns:[[
                    {field:itemid,title:Item ID,width:60},
                    {field:productid,title:Product,width:100,
                        formatter:function(value,row){
                            return row.productname || value;
                        },
                        editor:{
                            type:combobox,
                            options:{
                                valueField:productid,
                                textField:name,
                                data:products,
                                required:true
                            }
                        }
                    },
                    {field:listprice,title:List Price,width:80,align:right,editor:{type:numberbox,options:{precision:1}}},
                    {field:unitcost,title:Unit Cost,width:80,align:right,editor:numberbox},
                    {field:attr1,title:Attribute,width:180,editor:text},
                    {field:status,title:Status,width:50,align:center,
                        editor:{
                            type:checkbox,
                            options:{
                                on: P,
                                off: ‘‘
                            }
                        }
                    },
                    {field:action,title:Action,width:80,align:center,
                        formatter:function(value,row,index){
                            if (row.editing){
                                var s = <a href="javascript:void(0)" onclick="saverow(this)">Save</a> ;
                                var c = <a href="javascript:void(0)" onclick="cancelrow(this)">Cancel</a>;
                                return s+c;
                            } else {
                                var e = <a href="javascript:void(0)" onclick="editrow(this)">Edit</a> ;
                                var d = <a href="javascript:void(0)" onclick="deleterow(this)">Delete</a>;
                                return e+d;
                            }
                        }
                    }
                ]],
                onEndEdit:function(index,row){
                    var ed = $(this).datagrid(getEditor, {
                        index: index,
                        field: productid
                    });
                    row.productname = $(ed.target).combobox(getText);
                },
                onBeforeEdit:function(index,row){
                    row.editing = true;
                    $(this).datagrid(refreshRow, index);
                },
                onAfterEdit:function(index,row){
                    row.editing = false;
                    $(this).datagrid(refreshRow, index);
                },
                onCancelEdit:function(index,row){
                    row.editing = false;
                    $(this).datagrid(refreshRow, index);
                }
            });
        });
        function getRowIndex(target){
            var tr = $(target).closest(tr.datagrid-row);
            return parseInt(tr.attr(datagrid-row-index));
        }
        function editrow(target){
            $(#tt).datagrid(beginEdit, getRowIndex(target));
        }
        function deleterow(target){
            $.messager.confirm(Confirm,Are you sure?,function(r){
                if (r){
                    $(#tt).datagrid(deleteRow, getRowIndex(target));
                }
            });
        }
        function saverow(target){
            $(#tt).datagrid(endEdit, getRowIndex(target));
        }
        function cancelrow(target){
            $(#tt).datagrid(cancelEdit, getRowIndex(target));
        }
        function insert(){
            var row = $(#tt).datagrid(getSelected);
            if (row){
                var index = $(#tt).datagrid(getRowIndex, row);
            } else {
                index = 0;
            }
            $(#tt).datagrid(insertRow, {
                index: index,
                row:{
                    status:P
                }
            });
            $(#tt).datagrid(selectRow,index);
            $(#tt).datagrid(beginEdit,index);
        }
    </script>
    

希望可以帮到有类似需求的朋友。

 
      

Editable DataGrid 实现列表新增编辑功能

原文:http://www.cnblogs.com/-free/p/6102024.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!