上接扩展GridView控件(9) - 给数据行增加右键菜单

6、重写OnPreRender方法,注册上面那段客户端脚本
/// <summary> 
InBlock.gif                 /// OnPreRender 
InBlock.gif                 /// </summary> 
InBlock.gif                 /// <param name="e"></param> 
InBlock.gif                 protected  override  void OnPreRender(EventArgs e) 
InBlock.gif                { 
InBlock.gif                         if (ContextMenus.Count > 0) 
InBlock.gif                        { 
InBlock.gif                                StringBuilder sb =  new StringBuilder(); 
InBlock.gif                                 foreach (ContextMenu cm  in ContextMenus) 
InBlock.gif                                { 
InBlock.gif                                         // item = new contextItem("", "", "", "", "", ""); 
InBlock.gif                                         // 1-菜单项的文本 
InBlock.gif                                         // 2-图标链接 
InBlock.gif                                         // 3-所调用的命令按钮的ID 
InBlock.gif                                         // 4-链接地址 
InBlock.gif                                         // 5-链接的target 
InBlock.gif                                         // 6-右键菜单的项的类别 
InBlock.gif 
InBlock.gif                                         // 命令按钮 
InBlock.gif                                         if (cm.ItemType == ContextMenu.ItemTypeCollection.Command) 
InBlock.gif                                        { 
InBlock.gif                                                sb.Append( "item = new contextItem(\"" + cm.Text + 
InBlock.gif                                                         "\", \"" + ResolveUrl(cm.Icon) +  "\", \"" + 
InBlock.gif                                                        cm.CommandButtonId +  "\", \"\", \"\", \"Command\");"); 
InBlock.gif                                        } 
InBlock.gif                                         // 链接 
InBlock.gif                                         else  if (cm.ItemType == ContextMenu.ItemTypeCollection.Link) 
InBlock.gif                                        { 
InBlock.gif                                                sb.Append( "item = new contextItem(\"" + cm.Text + 
InBlock.gif                                                         "\", \"" + ResolveUrl(cm.Icon) +  "\", \"\", \"" + 
InBlock.gif                                                        cm.NavigateUrl +  "\", \"" + 
InBlock.gif                                                        cm.Target +  "\", \"Link\");"); 
InBlock.gif                                        } 
InBlock.gif                                         // 分隔线 
InBlock.gif                                         else  if (cm.ItemType == ContextMenu.ItemTypeCollection.Separator) 
InBlock.gif                                        { 
InBlock.gif                                                sb.Append( "item = new contextItem(\"\", \"\", \"\", \"\", \"\", \"Separator\");"); 
InBlock.gif                                        } 
InBlock.gif 
InBlock.gif                                        sb.Append( "myMenu.addItem(item);"); 
InBlock.gif                                } 
InBlock.gif 
InBlock.gif                                 // 注册客户端代码 
InBlock.gif                                 if (!Page.ClientScript.IsClientScriptBlockRegistered( "jsContextMenu")) 
InBlock.gif                                { 
InBlock.gif                                        Page.ClientScript.RegisterClientScriptBlock( 
InBlock.gif                                                 this.GetType(), 
InBlock.gif                                                 "jsContextMenu", JavaScriptConstant.jsContextMenu.Replace( "[$MakeMenu$]", sb.ToString()) 
InBlock.gif                                                ); 
InBlock.gif                                } 
InBlock.gif                        } 
InBlock.gif 
InBlock.gif                         base.OnPreRender(e); 
InBlock.gif                }
 
7、重写OnRowDataBound给数据行增加客户端代码以调用我们注册的那段javascript,从而实现给GridView的数据行增加右键菜单的功能。
/// <summary> 
InBlock.gif                 /// OnRowDataBound 
InBlock.gif                 /// </summary> 
InBlock.gif                 /// <param name="e"></param> 
InBlock.gif                 protected  override  void OnRowDataBound(GridViewRowEventArgs e) 
InBlock.gif                { 
InBlock.gif                         if (e.Row.RowType == DataControlRowType.DataRow) 
InBlock.gif                        { 
InBlock.gif                                 if (ContextMenus.Count > 0) 
InBlock.gif                                { 
InBlock.gif                                         // 给数据行增加客户端代码 
InBlock.gif                                        e.Row.Attributes.Add( "oncontextmenu""showMenu('" + e.Row.ClientID +  "');return false;"); 
InBlock.gif                                } 
InBlock.gif                        } 
InBlock.gif 
InBlock.gif                         base.OnRowDataBound(e); 
InBlock.gif                }
 
控件使用
添加这个控件到工具箱里,然后拖拽到webform上,设置如下属性:ItemType为右键菜单的项的类别(Link,Command,Separator);Icon为文字左边的图标的链接;Text为菜单的文字;CommandButtonId为所调用的命令按钮的ID;NavigateUrl为链接的url;Target为链接的target(Blank,Self,Top)
ObjData.cs
InBlock.gif using System; 
InBlock.gif using System.Data; 
InBlock.gif using System.Configuration; 
InBlock.gif using System.Web; 
InBlock.gif using System.Web.Security; 
InBlock.gif using System.Web.UI; 
InBlock.gif using System.Web.UI.WebControls; 
InBlock.gif using System.Web.UI.WebControls.WebParts; 
InBlock.gif using System.Web.UI.HtmlControls; 
InBlock.gif 
InBlock.gif using System.ComponentModel; 
InBlock.gif 
/// <summary> 
/// OjbData 的摘要说明 
/// </summary> 
InBlock.gif public  class OjbData 
InBlock.gif
InBlock.gif         public OjbData() 
InBlock.gif        { 
InBlock.gif                 // 
InBlock.gif                 // TODO: 在此处添加构造函数逻辑 
InBlock.gif                 // 
InBlock.gif        } 
InBlock.gif 
InBlock.gif        [DataObjectMethod(DataObjectMethodType.Select,  true)] 
InBlock.gif         public DataTable Select() 
InBlock.gif        { 
InBlock.gif                DataTable dt =  new DataTable(); 
InBlock.gif                dt.Columns.Add( "no"typeof( string)); 
InBlock.gif                dt.Columns.Add( "name"typeof( string)); 
InBlock.gif 
InBlock.gif                 for ( int i = 0; i < 30; i++) 
InBlock.gif                { 
InBlock.gif                        DataRow dr = dt.NewRow(); 
InBlock.gif                        dr[0] =  "no" + i.ToString().PadLeft(2, '0'); 
InBlock.gif                        dr[1] =  "name" + i.ToString().PadLeft(2, '0'); 
InBlock.gif 
InBlock.gif                        dt.Rows.Add(dr); 
InBlock.gif                } 
InBlock.gif 
InBlock.gif                 return dt; 
InBlock.gif        } 
InBlock.gif}
 
Default.aspx
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %> 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head runat="server"> 
        <title>SmartGridView测试</title> 
</head> 
<body> 
        <form id="form1" runat="server"> 
                <div> 
                        <yyc:SmartGridView ID="SmartGridView1" runat="server" DataSourceID="ObjectDataSource1" 
                                AutoGenerateColumns="false"> 
                                <Columns> 
                                        <asp:BoundField DataField="no" HeaderText="序号" SortExpression="no" ItemStyle-Width="100px" /> 
                                        <asp:BoundField DataField="name" HeaderText="名称" SortExpression="name" ItemStyle-Width="100px" /> 
                                        <asp:BoundField DataField="no" HeaderText="序号" SortExpression="no" ItemStyle-Width="100px" /> 
                                        <asp:BoundField DataField="name" HeaderText="名称" SortExpression="name" ItemStyle-Width="100px" /> 
                                        <asp:BoundField DataField="no" HeaderText="序号" SortExpression="no" ItemStyle-Width="100px" /> 
                                        <asp:BoundField DataField="name" HeaderText="名称" SortExpression="name" ItemStyle-Width="100px" /> 
                                        <asp:TemplateField> 
                                                <footerstyle cssclass="hidden" /> 
                                                <headerstyle cssclass="hidden" /> 
                                                <itemstyle cssclass="hidden" /> 
                                                <itemtemplate> 
                                        <asp:Button id="btnRightMenuButton" runat="server" CommandName="RightMenuButton" CommandArgument='<%# Container.DataItemIndex %>' /> 
                                </itemtemplate> 
                                        </asp:TemplateField> 
                                </Columns> 
                                <ContextMenus> 
                                        <yyc:ContextMenu ItemType="Command" Text="右键菜单按钮测试" Icon="~/Images/button.gif" CommandButtonId="btnRightMenuButton" /> 
                                        <yyc:ContextMenu ItemType="Separator" /> 
                                        <yyc:ContextMenu ItemType="Link" Text="控件源代码" Icon="~/Images/button.gif" NavigateUrl="http://webabcd.cnblogs.com" 
                                                Target="Blank" /> 
                                </ContextMenus> 
                        </yyc:SmartGridView> 
                        <asp:ObjectDataSource ID="ObjectDataSource1" runat="server" SelectMethod="Select" 
                                TypeName="OjbData"></asp:ObjectDataSource> 
                </div> 
        </form> 
</body> 
</html>
 
注:如果想修改右键菜单的样式,请自行修改javascript,我就不把他们弄出来了。
InBlock.gif /*测试版的实现 结束*/
 




     本文转自webabcd 51CTO博客,原文链接:http://blog.51cto.com/webabcd/345549,如需转载请自行联系原作者

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值