ext grid 单击事件

EXTJS GRID 中 单击行和单元格获得行或者单元格的内容(数据) 

Js代码   收藏代码
  1. grid.addListener('cellclick',cellclick);  
  2.   
  3. function cellclick(grid, rowIndex, columnIndex, e) {   
  4. var record = grid.getStore().getAt(rowIndex); //Get the Record   
  5. var fieldName = grid.getColumnModel().getDataIndex(columnIndex); //Get field name   
  6. var data = record.get(fieldName);   
  7. Ext.MessageBox.alert('show','当前选中的数据是'+data);   
  8. }  


------------------------------------------------------------------------------ 
Js代码   收藏代码
  1. grid.on('mouseover',function(e){//添加mouseover事件  
  2.  var index = grid.getView().findRowIndex(e.getTarget());//根据mouse所在的target可以取到列的位置  
  3.  if(index!==false){//当取到了正确的列时,(因为如果传入的target列没有取到的时候会返回false)  
  4.   var record = store.getAt(index);//把这列的record取出来  
  5.   var str = Ext.encode(record.data);//组装一个字符串,这个需要你自己来完成,这儿我把他序列化  
  6.   var rowEl = Ext.get(e.getTarget());//把target转换成Ext.Element对象  
  7.   rowEl.set({  
  8.    'ext:qtip':str  //设置它的tip属性  
  9.   },false);  
  10.     
  11.  }  
  12.   });  

--------------------------------------------------------------------------------- 

Js代码   收藏代码
  1.   listeners: {  
  2. 'cellclick':function(grid,rowIndex,columnIndex,e ){ }   
  3. }  
  4.   
  5. //这是单击grid单元格时,触发的事件  


Js代码   收藏代码
  1. grid.getView().getCell(rowIndex,columnIndex).style.background-color="#FF6600";   
  2. grid.getView().getCell(rowIndex,columnIndex).style.color="#FF6600";   
我要改变都是整个背景色,不是光是字的颜色。还有怎么能点一个单元格时候,让上次的点的单元格颜色恢复到原来呢??? 
把表格刷新下可以把以前单击而改变的颜色还原,grid.getView().refresh(); 然后再让这次单击的单元格变色。 
Js代码   收藏代码
  1. grid.getView().refresh();   
  2. grid.getView().getCell(rowIndex,columnIndex).style.backgroundColor="#FF9999";  

你可能感兴趣的:(ext grid 单击事件)