Aspose.Cells.GridWebでコンテキストメニューのアイテムを追加または削除する

ASP.NETマークアップを使用してコンテキストメニューアイテムを追加

次のASP.NETマークアップは、GridWebにコンテキストメニューアイテムを追加します。

For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-.NET
<CustomCommandButtons>
<acw:CustomCommandButton Command="MyContextMenuItemCommand" Text="ContextMenuItemText" CommandType="ContextMenuItem"></acw:CustomCommandButton>
</CustomCommandButtons>

上記のASP.NETマークアップでコンテキストメニューアイテムを追加した場合の全体的なASP.NETマークアップを以下に示します。“OnCustomCommand=“GridWeb1_CustomCommand"“属性に注意してください。これは、コンテキストメニューアイテムがクリックされたときに呼び出されるイベントハンドラの名前です。

For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-.NET
<acw:GridWeb ID="GridWeb1" runat="server" XhtmlMode="True" EnableAJAX="true" OnCustomCommand="GridWeb1_CustomCommand" EnableClientColumnOperations="False" EnableClientFreeze="False" EnableClientMergeOperations="False" EnableClientRowOperations="False" EnableStyleDialogbox="False">
<CustomCommandButtons>
<acw:CustomCommandButton Command="MyContextMenuItemCommand" Text="ContextMenuItemText" CommandType="ContextMenuItem"></acw:CustomCommandButton>
</CustomCommandButtons>
</acw:GridWeb>

上記のASP.NETマークアップを使用してコンテキストメニューアイテムを追加した後のコンテキストメニューアイテムの外観です。

todo:image_alt_text

コンテキストメニューアイテムがクリックされたときに実行されるイベントハンドラコードです。コードはまずコマンド名をチェックし、マッチする場合は、アクティブなGridWebワークシートのセルA1にテキストを追加し、テキストが見えるように最初の列の幅を40ユニットに設定します。

// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-.NET
// Event Handler for custom command event of GridWeb
protected void GridWeb1_CustomCommand(object sender, string command)
{
if (command.Equals("MyContextMenuItemCommand"))
{
// Accessing the active sheet
GridWorksheet sheet = GridWeb1.WorkSheets[GridWeb1.ActiveSheetIndex];
// Putting value to "A1" cell
sheet.Cells["A1"].PutValue("My Custom Context Menu Item is Clicked.");
// Set first column width to make the text visible
sheet.Cells.SetColumnWidth(0, 40);
}
}

上記のASP.NETマークアップを使用してコンテキストメニューアイテムを追加した後のGridWebの外観です。

todo:image_alt_text

コードを使用してAspose.Cells.GridWebにコンテキストメニューアイテムを追加する

このコードは、コードを使用してGridWeb内にコンテキストメニューアイテムを追加する方法を示しています。

// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-.NET
// Init context menu item command button
CustomCommandButton cmd = new CustomCommandButton();
cmd.CommandType = CustomCommandButtonType.ContextMenuItem;
cmd.Text = "MyNewContextMenuItem";
cmd.Command = "MyNewContextMenuItemCommand";
// Add context menu item command button to GridWeb
GridWeb1.CustomCommandButtons.Add(cmd);

コードを使用してAspose.Cells.GridWebからコンテキストメニューアイテムを削除する

このコードは、CustomCommandButtons.Remove()およびCustomCommandButtons.RemoveAt()メソッドを使用してコンテキストメニューアイテムを削除する方法を示しています。

// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-.NET
if (GridWeb1.CustomCommandButtons.Count > 1)
{
// Remove the 2nd custom command button or context menu item using remove at method
GridWeb1.CustomCommandButtons.RemoveAt(1);
}
if (GridWeb1.CustomCommandButtons.Count >= 1)
{
// Access the 1st custom command button or context menu item and remove it
CustomCommandButton custbtn = GridWeb1.CustomCommandButtons[0];
GridWeb1.CustomCommandButtons.Remove(custbtn);
}