关于Infragistics.WebUI.UltraWebGrid的使用

Infragistics.WebUI.UltraWebGrid功能比较强大,尤其是客户端时间比较丰富,能实现较多的控制。下面就有关个别客户端事件稍微说明一下。

 

在.cs代码中添加

 


UltraWebGrid1.DisplayLayout.ClientSideEvents.CellClickHandler = "Template_CellClickHandler";
UltraWebGrid1.DisplayLayout.ClientSideEvents.ColumnHeaderClickHandler 
= "Template_ColumnHeaderClickHandler";
UltraWebGrid1.DisplayLayout.ClientSideEvents.AfterCellUpdateHandler 
= "Template_AfterCellUpdateHandler";
UltraWebGrid1.DisplayLayout.ClientSideEvents.AfterRowActivateHandler 
= "Template_AfterRowActivateHandler";

 

以上四个分别为:单元格单击事件,列头单击事件,单元格更新后事件,选择行事件。

 

注意单元格单击事件需要在前面页面该控件的样式布局部分修改CellClickActionDefault="CellSelect",如果是

行选择CellClickActionDefault="RowSelect"


<DisplayLayout RowHeightDefault="24px" Version="4.00" BorderCollapseDefault="Separate" LoadOnDemand="Xml" TableLayout="Fixed" 
                 CellClickActionDefault
="CellSelect" SelectTypeRowDefault="Single" RowSelectorsDefault="No" SelectTypeCellDefault="Extended">

 

然后编写客户端事件

 


//声明几个常用的全局变量
var CurrentGrid=null;
var CurrentRowIndex=-1;
var CurrentColumnIndex=-1;
var CurrentRow=null;
var CurrentCell=null;

//单元格单击
function Template_CellClickHandler(gridName, cellId, button)
{   
    
if(button==2)
        
return;
        
    CurrentGrid
=igtbl_getGridById(UltraWebGrid1);
    CurrentCell
=CurrentGrid.getActiveCell();
    CurrentColumnIndex
=CurrentCell.Index;
    CurrentRow
=CurrentCell.Row;
    CurrentRowIndex
=CurrentRow.getIndex();

    
//其他你要执行的js代码
}

//行单击事件 
function Template_AfterRowActivateHandler(gridId,rowId)
{
    CurrentRow
=igtbl_getRowById(rowId);
    CurrentRowIndex
=CurrentRow.getIndex();

    
//其他你要执行的js代码
}

//表头单击事件(参数没写,自己找一下)
function Template_ColumnHeaderClickHandler()
{

}

//单元格更新后事件
function Template_AfterCellUpdateHandler(gridName, cellId)
{

}

 

 其他一些常用操作

 

 

function  DeleteRow()
{
    
var  row = igtbl_getActiveRow(UltraWebGrid1); 
    CurrentRow
= row;
    
// 有时需要执行一些检查,满足一定条件后然后执行一个回调函数来删除,所以将当前行保存在全局变量中
    CurrentRow.deleteRow();
}

 

添加行:

 

function  InsertRow()
{
    CurrentGrid
= igtbl_getGridById(UltraWebGrid1);
    CurrentGrid.Rows.addNew();

    
// 得到刚添加的行,可以return(返回)刚添加的行,然后进行自动赋值等操作
     var  row = igtbl_getRowById(CurrentGrid.Rows.getLastRowId());
    
// 得到当前行的下一行
     var  row = CurrentRow.getNextRow();
}

 

 

根据Id得到某个行或单元格

 

igtbl_getCellById(cellId);
igtbl_getRowById(rowId);

 

如果单元格是图片,可以这样赋值

addCell.Element.innerHTML = " <NOBR><IMG style=/ " CURSOR: hand/ "  οnclick=InsertRow() src=/ " .. / images / Default / add.bmp/">< / NOBR > " ;

 

如果是文本,应该

 

row.getCell(columnIndex);
cell.setValue();

 

更多使用技巧完善中!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值