GridView模板列,如何在后台代码中添加客户端事件,执行sql函数,格式化数据

1、在GridView中经常会有这样的操作,比如要删除一条记录,点击一个个ImageButton 或者 LinkButton 首先用脚本确认是否删除,然后确定之后,再执行这个ImageButton或者LinkButton的OnClick事件,执行删除,具体的操作如下:

<asp:GridView ID="gvClassInfoList" runat="server" Width="100%"  AutoGenerateColumns="False" DataKeyNames="ClassID"   > 
       <RowStyle CssClass="dataTable1Row" />
       <Columns>
       <asp:TemplateField HeaderText="班级ID" Visible="False">//这一列可以同样是BoundField列,主键列
             <ItemTemplate>
           <asp:Label ID="lblClassId" runat="server" Text='<%# Eval("ClassID") %>' Visible="false" ></asp:Label>
             </ItemTemplate>                        
       </asp:TemplateField>
       <asp:BoundField DataField="CLASSNO" HeaderText="班级代码" SortExpression="IS_REPLY">
          <ItemStyle Wrap="True" ForeColor="Red" HorizontalAlign="Center" Width="5%" />
          <HeaderStyle Wrap="False" />
       </asp:BoundField>

   <asp:BoundField DataField="PROGRAMNAME" HeaderText="培训项目"  SortExpression="PROGRAMNAME" />
       <asp:BoundField DataField="CLASSTYPE" HeaderText="类别 " SortExpression="CLASSTYPE"></asp:BoundField>
       <asp:BoundField DataField="TRAINEENO" HeaderText="总人数" SortExpression="TRAINEENO"></asp:BoundField>
       <asp:BoundField DataField="STARTDATE" HeaderText="理论开始时间" SortExpression="STARTDATE" HtmlEncode=false                                  DataFormatString="{0:yyyy-MM-dd}"></asp:BoundField>
       <asp:BoundField DataField="ENDDATE" HeaderText="理论结束时间" SortExpression="ENDDATE" HtmlEncode=false                       DataFormatString="{0:yyyy-MM-dd}"></asp:BoundField>//格式化数据
      <asp:BoundField DataField="DAYS" HeaderText="时长" SortExpression="DAYS"></asp:BoundField>
      <asp:BoundField DataField="FROMNO" HeaderText="延续自" SortExpression="FROMNO"></asp:BoundField>                    
      <asp:BoundField DataField="ATTENDNO" HeaderText="延续至" SortExpression="ATTENDNO"></asp:BoundField>                    
      <asp:BoundField DataField="WITHNO" HeaderText="合班" SortExpression="WITHNO"></asp:BoundField>                    
      <asp:BoundField DataField="ClassRoom" HeaderText="教室号" SortExpression="ClassRoom"></asp:BoundField>                    
      <asp:BoundField DataField="Receptionist" HeaderText="接待员"  SortExpression="Receptionist"></asp:BoundField>                    
      <asp:BoundField DataField="Remark" HeaderText="备注" SortExpression="Remark"></asp:BoundField>
      <asp:TemplateField HeaderText="团组资料">
            <ItemTemplate>
                <div>                                
                   <asp:Label ID="lblOrgName" runat="server" Text='<%#Eval("OrgNameAndTraineeNo") %>'></asp:Label>//由sql函数生成的字段

                </div>
            </ItemTemplate>
      </asp:TemplateField>
      <asp:TemplateField HeaderText="管理">
             <ItemTemplate>
                  <div>
                     <nobr>                                   
                          <asp:LinkButton ID="lkBtnModify" runat="server" >修改</asp:LinkButton>
                          <asp:LinkButton ID="lkBtnReset" runat="server" OnClientClick='javascritp:return confirm("确定要修改此班级状态吗?");'                            onclick="lkBtnReset_Click" >取消</asp:LinkButton>//执行客户端事件与onclick事件
                          <asp:LinkButton ID="lkBtnLookOrg" runat="server" >查看团组</asp:LinkButton>
                          <asp:LinkButton ID="lkBtnAddOrg" runat="server" >添加团组</asp:LinkButton>                                   
                     </nobr>
                  </div>
            </ItemTemplate>
        </asp:TemplateField>
      </Columns>
      <HeaderStyle BorderStyle="None" CssClass="dataTable1HeaderCellWithSorting" BorderWidth="5px" />
       <AlternatingRowStyle BorderStyle="None" CssClass="dataTable1Row" />
</asp:GridView>

 

//2、以下为模板列中lkBtnReset的onclick事件

/// <summary>
        /// 将班级信息的ColName1即显示状态修改为0,不显示
        /// </summary>       
        protected void lkBtnReset_Click(object sender, EventArgs e)
        {
            GridViewRow gvr = (sender as LinkButton).NamingContainer as GridViewRow;
            string key = gvClassInfoList.DataKeys[gvr.RowIndex].Value.ToString();//获取gridview的主键
            IClass bll = BLLAccess.CreateClass();
            ClassBasic obj = bll.GetModelByClassID(key);
            obj.ColName1 = "0";
            string classId = bll.UpdateClass(obj);
            if (!string.IsNullOrEmpty(classId))
            {
                AlertMessage("修改成功!");
            }
            else
            {
                AlertMessage("修改失败!");
            }
        }

 

 

//3、在后台代码中添加客户端事件

/// <summary>
/// 对GridView中每一行的linkButton添加客户端的onclick事件,打开一个查看团组的模态窗口
/// </summary>
/// <param name="ds">绑定到GridView中的数据源</param>
private void AddEvent(DataSet ds)
{
    try
    {
        if (ds != null && ds.Tables[0].Rows.Count > 0)
        {
            foreach (GridViewRow gr in gvClassInfoList.Rows)
            {
                LinkButton lkBtn = (LinkButton)gr.Cells[15].FindControl("lkBtnLookOrg");
                LinkButton lkBtnAddOrg = (LinkButton)gr.Cells[15].FindControl("lkBtnAddOrg");
                LinkButton lkBtnModify = (LinkButton)gr.Cells[15].FindControl("lkBtnModify");

                //string str = ((Label)gr.Cells[0].FindControl("lblText")).Text;                     
                string classid = ((Label)gr.Cells[0].FindControl("lblClassId")).Text;

      //下面为添加客户端的脚本事件,打开对话框。函数在javascript中
                lkBtn.Attributes.Add("onclick", "return UniversalOpenWindow(760,550,'ScanOrgInfo.aspx?classid=" + classid + "');");
                lkBtnAddOrg.Attributes.Add("onclick", "return UniversalOpenWindow(760,550,'NewClassOrganization.aspx?classid=" + classid + "');");
                lkBtnModify.Attributes.Add("onclick", "return UniversalOpenWindow(760,550,'NewClass.aspx?classid=" + classid + "');");
            }
        }
    }
    catch (Exception e)
    {
        throw e;
    }
}

 

 //分页的sql与执行sql函数,GetOrgNameAndTraineeNos函数在SQL SERVER系列中

/// <summary>
/// 获取分页的sql语句
/// </summary>
/// <param name="startIndex">起始记录下标,默认从0开始</param>
/// <param name="endindex">本页记录的最后一个下标</param>
/// <param name="sqlWhere">查询条件</param>
/// <returns>返回条件查询字符串</returns>
private string GetPagingString(int startIndex, int endIndex, string sqlWhere)
{
    string sqlWhere1 = " WHERE 1=1 And c.ColName1='1' ";//ColName=1即为可显示的数据
    string strSql = "begin "
            + " WITH list AS ( "
            + " SELECT ROW_NUMBER() OVER (ORDER BY c.ClassNo DESC)AS Row, c.ClassID,c.CLASSNO,c.ProgramName,c.ClassType,"
            + " c.TraineeNo,c.StartDate,c.EndDate,c.Days,c.FromNo,c.AttendNo,c.WithNo,c.ClassRoom,c.Receptionist,c.Remark,"
            + " dbo.GetOrgNameAndTraineeNos(c.ClassID) as OrgNameAndTraineeNo "//执行sql函数,拼接该班级ID下的所以团组及人数
            + " from ClassBasic c ";

    if (!string.IsNullOrEmpty(sqlWhere))
    {
        sqlWhere1 += sqlWhere;
        strSql += sqlWhere1 + " )"
            + "  SELECT * FROM list WHERE Row between " + startIndex + " and " + endIndex + ""
            + " end";
    }
    else
    {
        strSql += " )"
            + "  SELECT * FROM list WHERE Row between " + startIndex + " and " + endIndex + ""
            + " end";
    }
    return strSql;
}

 

 

 

posted @ 2010-06-21 10:30  Vihone  阅读(1581)  评论(0编辑  收藏  举报