利用JavaScript选择GridView行

   本篇技巧和诀窍记录的是:利用JavaScript选择GridView行。

当我们想在GridView中添加删除、选择功能时,我们通常的做法是利用模板功能在每行添加一个按钮控件或者超链接按钮控件,单击按钮利用RowCommand获取每行的ID。

下面我们利用JavaScript完成这一功能。
我们可以通过调用JavaScirpt函数改变单击的行的背景颜色来模拟选择的行,这里需要声明一个隐藏字段,从JS中获得选取GridView行的ID。在选择/删除事件中,可以从隐藏字段中得到选择行的ID,完成一些需要功能。

第一步:在页面中添加GridView控件和一个按钮,隐藏字段

 

 

ExpandedBlockStart.gif 代码
< input  id ="hdnEmailID"  type ="hidden"  
       value
="0"  runat ="server"  name ="hdnEmailID"   />
< asp:GridView  ID ="gvUsers"  runat ="server"  
              AutoGenerateColumns
="False"  
              OnRowDataBound
="gvUsers_RowDataBound" >
    
< Columns >
        
< asp:BoundField  DataField ="Email"  HeaderText ="邮件"  ReadOnly ="True"   />
        
< asp:BoundField  DataField ="Name"  HeaderText ="姓名"  ReadOnly ="True"   />
    
</ Columns >
</ asp:GridView >
< asp:Button  ID ="btnSelect"  runat ="server"  
            OnClick
="btnSelect_Click"  Text ="Select"   />

 

 

 

 

第二步:编写JS函数来获取选择行的id,并改变背景颜色

 

ExpandedBlockStart.gif 代码
< script language = " javascript "  type = " text/javascript " >
    
var  lastRowSelected;
    
var  originalColor;
    
function  GridView_selectRow(row, EmailID)
    { 
          
var  hdn = document.form1.hdnEmailID;
          hdn.value 
=  EmailID;
          
if  (lastRowSelected  !=  row)
            {
            
if  (lastRowSelected  !=   null )
             {
              lastRowSelected.style.backgroundColor 
=  originalColor;
              lastRowSelected.style.color 
=   ' Black '
              lastRowSelected.style.fontWeight 
=   ' normal ' ;
             }
          originalColor 
=  row.style.backgroundColor
          row.style.backgroundColor 
=   ' BLACK '
          row.style.color 
=   ' White '
          row.style.fontWeight 
=   ' normal '
          lastRowSelected 
=  row;
          }
    }

    
function  GridView_mouseHover(row)
    {
        row.style.cursor 
=   ' hand ' ;
    }
< / script>

 

 

略过一步,就是绑定数据,大家自行完成。

第三步:在RowDataBound事件中添加JS函数调用。

 

ExpandedBlockStart.gif 代码
protected   void  gvUsers_RowDataBound( object  sender, GridViewRowEventArgs e)
{
    
if  (e.Row.RowType  ==  DataControlRowType.DataRow)
    {
        e.Row.ID 
=  e.Row.Cells[ 0 ].Text;
        e.Row.Attributes.Add(
" onclick "
            
" GridView_selectRow(this,' "   +  e.Row.Cells[ 0 ].Text  +   " ') " );
        e.Row.Attributes.Add(
" onmouseover " " GridView_mouseHover(this) " );
    }
}

 

 

第四步:完成按钮事件

在选择/删除按钮单击事件我们可以用hdnEmailID.Value方式获得行的id。然后利用id来完成操作;这里为了演示,我只是输出了这个值。

 

protected   void  btnSelect_Click( object  sender, EventArgs e)
{
     Response.Write(hdnEmailID.Value);
}

 

 

好了,这个技巧就介绍到这里了,大家试一试!

转自:http://www.cnblogs.com/lyj/archive/2008/05/10/1191275.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用DevExpress GridControl控件中,如果需要添加新,可以通过以下步骤实现: 1. 首先,在GridControl控件中选中想要添加新的数据源,比如DataTable、List等。 2. 然后,在GridControl控件的Designer视图中设置控件的AllowAddNewRow属性为True。 3. 接着,在代码中调用GridView控件的AddNewRow方法,启动添加新操作。 4. 在GridView控件的InitNewRow事件中,对新初始化,比如设置默认值等。 5. 最后,将新添加到数据源中,刷新GridView的数据显示。 下面是示例代码: 1. 在GridControl控件的Designer视图中设置AllowAddNewRow属性为True: ![image](https://user-images.githubusercontent.com/8575679/137455672-6dfeefa6-0ed6-4c6b-8d1e-0cfa34dde057.png) 2. 在代码中调用GridView的AddNewRow方法启动添加新操作: ``` gridView1.AddNewRow(); ``` 3. 在GridView的InitNewRow事件中进的初始化: ``` private void gridView1_InitNewRow(object sender, DevExpress.XtraGrid.Views.Grid.InitNewRowEventArgs e) { gridView1.SetRowCellValue(e.RowHandle, "ID", 0); gridView1.SetRowCellValue(e.RowHandle, "Name", "New Row"); } ``` 这里通过SetRowCellValue方法设置新的ID和Name属性值。 4. 最后,在代码中将新添加到数据源中,刷新GridView的数据显示: ``` dataTable.Rows.Add(gridView1.GetDataRow(gridView1.FocusedRowHandle)); gridView1.RefreshData(); ``` 这里通过Add方法将新添加到DataTable中,然后调用GridView的RefreshData方法刷新数据显示。 以上就是在DevExpress GridControl控件中添加新的步骤,实现起来相对简单。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值