149extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除                failure: function(response) extjs学习笔记(六--2) grid中数据的保存,添加和删除{
150extjs学习笔记(六--2) grid中数据的保存,添加和删除                    Ext.Msg.alert("警告""数据更新失败,请稍后再试!");
151extjs学习笔记(六--2) grid中数据的保存,添加和删除                }

152extjs学习笔记(六--2) grid中数据的保存,添加和删除            });
153extjs学习笔记(六--2) grid中数据的保存,添加和删除        }
154extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除        else extjs学习笔记(六--2) grid中数据的保存,添加和删除{
155extjs学习笔记(六--2) grid中数据的保存,添加和删除            Ext.Msg.alert("警告""没有任何需要更新的数据!");
156extjs学习笔记(六--2) grid中数据的保存,添加和删除        }

157extjs学习笔记(六--2) grid中数据的保存,添加和删除    }
158extjs学习笔记(六--2) grid中数据的保存,添加和删除
159extjs学习笔记(六--2) grid中数据的保存,添加和删除    //编辑后触发的事件,可在此进行数据有效性的验证
160extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除    function afterEdit(e) extjs学习笔记(六--2) grid中数据的保存,添加和删除{
161extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除        if (e.field == "common"extjs学习笔记(六--2) grid中数据的保存,添加和删除{
162extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除            if (e.value == "大笨"extjs学习笔记(六--2) grid中数据的保存,添加和删除{
163extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除                Ext.Msg.alert("错误""大笨是人物不是植物"function() extjs学习笔记(六--2) grid中数据的保存,添加和删除{ grid.startEditing(e.row, e.column) });
164extjs学习笔记(六--2) grid中数据的保存,添加和删除            }

165extjs学习笔记(六--2) grid中数据的保存,添加和删除        }

166extjs学习笔记(六--2) grid中数据的保存,添加和删除    }

167extjs学习笔记(六--2) grid中数据的保存,添加和删除});

    红色部分是新增加的代码,我们首先给grid增加了一个afterEdit事件,顾名思义,该事件在编辑之后被触发,我们可以在此时对数据的有效性进行验证,在本例中,我们只是简单的让common列的值不能等于一个特定的字符串,实际的项目中可能需要对每一列用正则表达式来进行验证。在触发afterEdit事件的时候会传递一个事件对象,该对象有如下几个属性:
    grid:当前grid。
    record:当前行。
    field:当前列名。
    value:被设置的值。
    originalValue:编辑前的值。
     row:行索引。
    column:列索引。

     我们还在grid上加了一个工具栏,上边放了一个保存按钮,用以将修改后的数据传递到服务器进行保存。由于记录的集合是一个复杂的json对象,我们需要的只是相关数据的几个,因此第137-140行对该集合进行了处理。当然,我们还需要在服务器端接收数据然后进行处理,在系列一中我们已经学习到相关的方法,这里不再赘述。我们看一看运行之后的效果图:

 extjs学习笔记(六--2) grid中数据的保存,添加和删除

     通过firebug,我们可以看到向服务器投递的数据:

extjs学习笔记(六--2) grid中数据的保存,添加和删除 

     接下来看看如何添加数据,我们在工具栏里边添加一个增加按钮,相关代码如下:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> 1extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除tbar: [extjs学习笔记(六--2) grid中数据的保存,添加和删除{
 2extjs学习笔记(六--2) grid中数据的保存,添加和删除            text: "保存",
 3extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除            handler: function() extjs学习笔记(六--2) grid中数据的保存,添加和删除{
 4extjs学习笔记(六--2) grid中数据的保存,添加和删除                var modified = store.modified;
 5extjs学习笔记(六--2) grid中数据的保存,添加和删除
 6extjs学习笔记(六--2) grid中数据的保存,添加和删除                updateData(modified);
 7extjs学习笔记(六--2) grid中数据的保存,添加和删除            }

 8extjs学习笔记(六--2) grid中数据的保存,添加和删除        }
,
 9extjs学习笔记(六--2) grid中数据的保存,添加和删除            '-',
10extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除            extjs学习笔记(六--2) grid中数据的保存,添加和删除{
11extjs学习笔记(六--2) grid中数据的保存,添加和删除                text: "增加",
12extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除                handler: function() extjs学习笔记(六--2) grid中数据的保存,添加和删除{
13extjs学习笔记(六--2) grid中数据的保存,添加和删除                    var Plant = store.recordType;
14extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除                    var p = new Plant(extjs学习笔记(六--2) grid中数据的保存,添加和删除{
15extjs学习笔记(六--2) grid中数据的保存,添加和删除                        common: 'New Plant 1',
16extjs学习笔记(六--2) grid中数据的保存,添加和删除                        light: 'Mostly Shade',
17extjs学习笔记(六--2) grid中数据的保存,添加和删除                        price: 0,
18extjs学习笔记(六--2) grid中数据的保存,添加和删除                        availDate: (new Date()).clearTime(),
19extjs学习笔记(六--2) grid中数据的保存,添加和删除                        indoor: false
20extjs学习笔记(六--2) grid中数据的保存,添加和删除                    }
);
21extjs学习笔记(六--2) grid中数据的保存,添加和删除                    grid.stopEditing();
22extjs学习笔记(六--2) grid中数据的保存,添加和删除                    store.insert(0, p);
23extjs学习笔记(六--2) grid中数据的保存,添加和删除                    grid.startEditing(00);
24extjs学习笔记(六--2) grid中数据的保存,添加和删除                }

25extjs学习笔记(六--2) grid中数据的保存,添加和删除            }

26extjs学习笔记(六--2) grid中数据的保存,添加和删除                ]

     在向grid中插入数据之前,必须要先获得插入数据的格式,Store类的recordType属性返回Record的构造函数,表明了数据的格式,然后通过构造函数传递数据,这样就准备好了要插入的数据了。接下来将grid的编辑状态关闭,插入数据,然后把要插入数据的第一列设置为编辑状态。运行后点击增加按钮后的效果如下:

extjs学习笔记(六--2) grid中数据的保存,添加和删除 

     可以看到,在grid的最上边增加了一行,对应行索引0,第一列出于编辑状态,对应列索引1,增加行中的默认初始数据就是我们在构造函数中传递进来的数据。注意,新增加的数据在修改之前是不会保存在store的modified属性里边的。

    我们再来看看如何进行删除操作。在进行删除之前,我们必须要选择需要删除的行,grid有单元格选择模型和行选择模型两种,分别以类CellSelectionModel和RowSelectionModel来表示,默认是单元格选择模型,也就是在点击单元格的时候选中的是当前单元格,可以通过配置属性selModle(可简写为sm)来指定选择模式:sm:new Ext.grid.RowSelectionModel({singleSelection:true}), 这样就把选择模型改为了行选择模型,参数singleSelect指明是否是单选的,为真的时候只能选择一行,默认是false,可以按下ctrl键或者shift键进行多行的选择。选择好之后,我们就来看看如何删除吧:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> 1extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除tbar: [extjs学习笔记(六--2) grid中数据的保存,添加和删除{
 2extjs学习笔记(六--2) grid中数据的保存,添加和删除            text: "保存",
 3extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除            handler: function() extjs学习笔记(六--2) grid中数据的保存,添加和删除{
 4extjs学习笔记(六--2) grid中数据的保存,添加和删除                var modified = store.modified;
 5extjs学习笔记(六--2) grid中数据的保存,添加和删除                updateData(modified);
 6extjs学习笔记(六--2) grid中数据的保存,添加和删除            }

 7extjs学习笔记(六--2) grid中数据的保存,添加和删除        }
,
 8extjs学习笔记(六--2) grid中数据的保存,添加和删除            '-',
 9extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除            extjs学习笔记(六--2) grid中数据的保存,添加和删除{
10extjs学习笔记(六--2) grid中数据的保存,添加和删除                text: "增加",
11extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除                handler: function() extjs学习笔记(六--2) grid中数据的保存,添加和删除{
12extjs学习笔记(六--2) grid中数据的保存,添加和删除                    var Plant = store.recordType;
13extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除                    var p = new Plant(extjs学习笔记(六--2) grid中数据的保存,添加和删除{
14extjs学习笔记(六--2) grid中数据的保存,添加和删除                        common: 'New Plant 1',
15extjs学习笔记(六--2) grid中数据的保存,添加和删除                        light: 'Mostly Shade',
16extjs学习笔记(六--2) grid中数据的保存,添加和删除                        price: 0,
17extjs学习笔记(六--2) grid中数据的保存,添加和删除                        availDate: (new Date()).clearTime(),
18extjs学习笔记(六--2) grid中数据的保存,添加和删除                        indoor: false
19extjs学习笔记(六--2) grid中数据的保存,添加和删除                    }
);
20extjs学习笔记(六--2) grid中数据的保存,添加和删除                    grid.stopEditing();
21extjs学习笔记(六--2) grid中数据的保存,添加和删除                    store.insert(0, p);
22extjs学习笔记(六--2) grid中数据的保存,添加和删除                    grid.startEditing(00);
23extjs学习笔记(六--2) grid中数据的保存,添加和删除                }

24extjs学习笔记(六--2) grid中数据的保存,添加和删除            }
,
25extjs学习笔记(六--2) grid中数据的保存,添加和删除            " ",
26extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除            extjs学习笔记(六--2) grid中数据的保存,添加和删除{
27extjs学习笔记(六--2) grid中数据的保存,添加和删除                text: "删除",
28extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除                handler: function() extjs学习笔记(六--2) grid中数据的保存,添加和删除{
29extjs学习笔记(六--2) grid中数据的保存,添加和删除                    var selModel = grid.getSelectionModel();
30extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除                    if (selModel.hasSelection()) extjs学习笔记(六--2) grid中数据的保存,添加和删除{
31extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除                        Ext.Msg.confirm("警告""确定要删除吗?"function(button) extjs学习笔记(六--2) grid中数据的保存,添加和删除{
32extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除                            if (button == "yes"extjs学习笔记(六--2) grid中数据的保存,添加和删除{
33extjs学习笔记(六--2) grid中数据的保存,添加和删除                                var selections = selModel.getSelections();
34extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除                                Ext.each(selections, function(item) extjs学习笔记(六--2) grid中数据的保存,添加和删除{
35extjs学习笔记(六--2) grid中数据的保存,添加和删除                                    store.remove(item);
36extjs学习笔记(六--2) grid中数据的保存,添加和删除                                }
);
37extjs学习笔记(六--2) grid中数据的保存,添加和删除                            }

38extjs学习笔记(六--2) grid中数据的保存,添加和删除                        }
);
39extjs学习笔记(六--2) grid中数据的保存,添加和删除                    }

40extjs学习笔记(六--2) grid中数据的保存,添加和删除extjs学习笔记(六--2) grid中数据的保存,添加和删除                    else extjs学习笔记(六--2) grid中数据的保存,添加和删除{
41extjs学习笔记(六--2) grid中数据的保存,添加和删除                        Ext.Msg.alert("错误""没有任何行被选中,无法进行删除操作!");
42extjs学习笔记(六--2) grid中数据的保存,添加和删除                    }

43extjs学习笔记(六--2) grid中数据的保存,添加和删除                }

44extjs学习笔记(六--2) grid中数据的保存,添加和删除            }

45extjs学习笔记(六--2) grid中数据的保存,添加和删除                ]

相关文章:

  • 2021-10-12
  • 2021-07-05
  • 2021-11-18
  • 2021-08-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-07-08
猜你喜欢
  • 2022-12-23
  • 2021-09-05
  • 2021-12-11
  • 2021-07-10
  • 2021-10-11
  • 2021-05-20
相关资源
相似解决方案