如何从GXT中的网格单元格中检索值

时间:2011-02-24 14:32:12

标签: eclipse gxt

我创建了一个可编辑的网格,其中只有3列的5个可编辑。我没有得到如何从特定单元格中检索值,因此可以动态地添加值并显示在同一网格的另一个单元格中。我在eclipse galileo中尝试过这段代码。但它不起作用。请帮帮我。

package org.openxdata.analyzer.client;

import java.util.ArrayList;
import com.extjs.gxt.ui.client.widget.grid.ColumnConfig;  
import com.google.gwt.user.client.Element;
import com.extjs.gxt.ui.client.widget.grid.ColumnModel;  
import com.extjs.gxt.ui.client.Style.HorizontalAlignment;  
import java.util.List;
import com.extjs.gxt.ui.client.store.ListStore;
import com.extjs.gxt.ui.client.widget.MessageBox;
import com.extjs.gxt.ui.client.widget.Window;
import com.extjs.gxt.ui.client.widget.button.Button;
import com.extjs.gxt.ui.client.widget.form.TextField;  
import com.extjs.gxt.ui.client.widget.grid.CellEditor;  
import com.extjs.gxt.ui.client.widget.grid.EditorGrid;  
import com.extjs.gxt.ui.client.widget.layout.FitLayout;  
import com.extjs.gxt.ui.client.widget.layout.FormData;
import com.extjs.gxt.ui.client.data.BaseModel;
import com.extjs.gxt.ui.client.event.ButtonEvent;
import com.extjs.gxt.ui.client.event.SelectionListener;
import com.extjs.gxt.ui.client.widget.Viewport;
import com.extjs.gxt.ui.client.widget.form.NumberField;


public class Grid1 extends Viewport {

    @Override
    protected void onRender(Element parent, int index) {
        super.onRender(parent, index);
        setStyleAttribute("margin", "10px");



        final Window w = new Window();
        w.setHeading("grids");
        w.setSize(600,250);
        w.setModal(true);
        //w.setLayout(new RowLayout(Orientation.VERTICAL)); 
        w.setLayout(new FitLayout());
        w.setResizable(false);

        FormData formData = new FormData("98%");


        List<ColumnConfig> col = new ArrayList<ColumnConfig>();
        ColumnConfig column = new ColumnConfig();
        column.setId("disease");
        column.setWidth(150);
        TextField<String> text = new TextField<String>();    
        text.setAllowBlank(false);    
        text.setAutoValidate(true);    
        //column.setEditor(new CellEditor(text));  
        col.add(column);


        column = new ColumnConfig();
        column.setId("exposure");
        column.setWidth(120);
        TextField<String> text1 = new TextField<String>();    
        text1.setAllowBlank(false);    
        text1.setAutoValidate(true);    
        //column.setEditor(new CellEditor(text1));  
        col.add(column);

        column = new ColumnConfig();
        column.setId("plus");
        column.setHeader("Exposure");
        column.setWidth(80);
    final NumberField text2 = new NumberField();    
        text2.setAllowBlank(false);    
        text2.setAutoValidate(true);    
        column.setEditor(new CellEditor(text2));  
        col.add(column);

        column = new ColumnConfig();
        column.setId("minus");
        column.setHeader("Exposure");
        column.setWidth(80);
        final NumberField text3 = new NumberField();   
        text3.setAllowBlank(false);    
        text3.setAutoValidate(true);    
        column.setEditor(new CellEditor(text3));  
        col.add(column);

        column = new ColumnConfig();
        column.setId("total");
        column.setHeader("Totals");
        column.setWidth(80);
        final NumberField text4 = new NumberField();      
        text4.setAllowBlank(false);    
        text4.setAutoValidate(true);    
        column.setEditor(new CellEditor(text4));  
        column.setAlignment(HorizontalAlignment.RIGHT);
        col.add(column);
        //ColumnModel cm = new ColumnModel(col);

        ListStore<Grid2> employeeList = new ListStore<Grid2>();    
        employeeList.add(cool.getgrid());


        ColumnModel cm = new ColumnModel(col);  


        final EditorGrid<Grid2> grid = new EditorGrid<Grid2>(employeeList, cm);  
        //grid.setStyleAttribute("borderTop", "none");  
        //grid.setAutoExpandColumn("name");  
        grid.setBorders(true);  
        grid.setStripeRows(true);  
          Button calculate = new Button("Calculate");
            w.addButton(calculate);



            calculate.addSelectionListener( new SelectionListener<ButtonEvent>()

                    {


                 @Override  
                    public void componentSelected(ButtonEvent ce) {  
                    {   

                        Double   p=(Double)text2.getValue();
                        Double m=(Double)text3.getValue();


                        Double t=p+m;

                        text4.setValue(t);

                        }  
                 }

                    });



        w.add(grid);
        w.show();
    }
}


class Grid2 extends BaseModel {
    private static final long serialVersionUID = 1L;
    public Grid2(){
    }
    public Grid2  ( String  dis, String exp, Integer x,Integer y) {
        set("disease", dis);
        set("exposure", exp);
        set("plus", x);
        set("minus", y);
    }

    public Grid2 (String  dis, String exp, Integer x,
            Integer y, Double v) {
        // this(dis, exp, x,y,v);
        set("disease", dis);
        set("exposure", exp);
        set("plus", x);
        set("minus", y);
        set("total", v);
    }
    public Grid2(String a,String b,String c,String d,String t){
        set("disease",a);
        set("exposure",b);
        set("plus",c);
        set("minus",d);
        set("total",t);
    }
    public  Integer getplus() {
        return (Integer)get("plus");
    }
    public Integer getminus() {
        return (Integer)get("minus");
    }


    public class TestData {  

        public  List<Grid2> getData()  
        {  
            List<Grid2> lt= new ArrayList<Grid2>();  



            lt.add(new Grid2("Christina Blake","Information Technology",1,2,1.23));  
            lt.add(new Grid2("Heriberto Rush","Information Technology",3,4,1.334));  

            return lt;  
        }  
    }  

}

class cool {  

    public static  List<Grid2> getgrid()  
    {  
        List<Grid2> data = new ArrayList<Grid2>();  

        //data.add(new Grid(" "," ","Exposure"," ","Totals"));  
        data.add(new Grid2(" "," ","(+)","(-)"," "));  
        data.add(new Grid2("'Disease'","(+)",0,0,0.00));  
        data.add(new Grid2(" ","(-)",0,0,0.00));  
        data.add(new Grid2("Totals"," ",0,0,0.00));  


        return data;  
    }  

}

4 个答案:

答案 0 :(得分:2)

如果您要修改任何可编辑的单元格,那么您可以获得store.getModifiedRecords()。它会给你修改过的记录。此记录可以为您提供对记录所做的更改。我认为record.getChanges()方法会返回该模型的地图(记录)。那时每个模型代表一个row.u可以得到被修改为密钥的单元格号以及与之对应的值。

之后你可以做store.removeAll()。然后添加以前的数据以及必须与相应的columconfig绑定的新数据。

然后致电store.add(List of models containing whole data)。 然后grid.recalculate();

答案 1 :(得分:1)

将StoreListener添加到网格后面的ListStore。处理更新事件并设置

答案 2 :(得分:1)

这会对你有所帮助。我通过这个获得了价值:

GridCellRenderer<Grid2> checkStatus = new GridCellRenderer<Grid2>() {
    public Object render(Grid2 model, String property,
            ColumnData config, int rowIndex, int colIndex,
            ListStore<Grid2> store, Grid<Grid2> grid) {
        int val = model.get(property);
        return val;
    }
};

答案 3 :(得分:0)

适用于gxt 2.x. store.getModifiedRecords().get(0).getChanges() - 返回Map,其中字段名称为键,旧单元格值为map的值。 store.getModifiedRecords().get(0).get("field_name")以String

的形式返回新值