GridJsのカスタムコンテキストメニュー
カスタムビルトインコンテキストメニュー
例:行/列の挿入/削除などのビルトインコンテキストメニュー項目があります。 例:GridJsのdiv idを “gridjs-divid” と仮定し、「削除行」、「リンク」、「非表示」メニュー項目をコンテキストメニューから削除します
//get context menus parent dom
const menus=document.querySelector("#gridjs-divid > div > div.x-spreadsheet-sheet > div.x-spreadsheet-contextmenu");
var childs = menus.childNodes;
for (var i = childs.length - 1; i >= 0; i--)
{
// check the item text
if(childs[i].childNodes[0]?.textContent==="Delete row"||childs[i].childNodes[0]?.textContent==="Link"||childs[i].childNodes[0]?.textContent==="Hide")
{
menus.removeChild(childs[i]);
}
}
この関数を呼び出した後
カスタム自己定義コンテキストメニュー
例:行/列の挿入/削除などのビルトインコンテキストメニュー項目があります。 ただし、ユーザーがカスタムコンテキストメニューアイテムを使用したい場合は。 ロードオプションでコンテキストメニューアイテムを設定するサポートを行っています。 たとえば:
const onMyActionClick1 = (sheet) => {
console.log('my action clicked1' + sheet.data.name)
};
const onMyActionClick2 = (sheet) => {
console.log('my action clicked2' + sheet.data.name)
};
xs = x_spreadsheet('#gridjs-demo', {
updateMode: 'server',
updateUrl: '/GridJs2/UpdateCell',
showToolbar: true,
mode: 'edit',
local: 'en',
showContextmenu: true,
//this option is for context menus,we need to set usedefault to false to load custom context menus
contextMenuItems: {
usedefault: false,
customItems: [{ 'key': 'key1', 'text': 'c title 11111', 'callback': onMyActionClick1 },
{ 'key': 'key2', 'text': 'c title 22222', 'callback': onMyActionClick2 }]
}
})
ランタイムでカスタムコンテキストメニューアイテムのために以下のJS APIをサポートしています
- カスタムコンテキストメニューアイテムを取得する
xs.sheet.getCustomContextMenuItems()
- カスタムコンテキストメニューアイテムを追加する
xs.sheet.addCustomContextMenuItems(itemsarray)
// the parameter is:
itemsarray: the array of custom menu items,the callback function x parameter will be the js variable of xs.sheet
for example: [{'key':'key4','text':'menu4','callback':(x)=>{console.log('hello4444');}},{'key':'key3','text':'menu3','callback':(x)=>{console.log('hello3333');}}]
- カスタムコンテキストメニューアイテムを削除する
xs.sheet.delCustomContextMenuItems(keysarray)()
// the parameter is:
keysarray: the array of the keys of the menu items
for example: ['key4','key3']
- 指定した位置にカスタムコンテキストメニューアイテムを挿入する
xs.sheet.insertCustomContextMenuItem(item,postion)
// the parameter is:
item: the custom menu item,the callback function x parameter will be the js variable of xs.sheet
for example: {'key':'key4','text':'menu4','callback':(x)=>{console.log('hello4444');}}
postion:the postion for the inserted item in the items array
- キーによってカスタムコンテキストメニューアイテムを更新する
xs.sheet.updateCustomContextMenuItem(key,item)
// the parameter is:
item: the updated properties that with text or callback
for example: {'text':'menu updated'}
key:the key of the menu item
- 画像/図形のためのカスタムコンテキストメニューアイテムを取得する
xs.sheet.getImageContextMenuItems()
- 画像/図形のためのカスタムコンテキストメニューアイテムを追加する
xs.sheet.addImageContextMenuItems(itemsarray)
// the parameter is:
itemsarray: the array of custom menu items,the callback function x parameter will be the js variable of xs.sheet
for example: [{'key':'key4','text':'img operation1','callback':(x)=>{console.log('operation1 on image');}},{'key':'key3','text':'img operation2','callback':(x)=>{console.log('operation2 on image');}}]
- 画像/図形のためのカスタムコンテキストメニューアイテムを削除する
xs.sheet.delImageContextMenuItems(keysarray)()
// the parameter is:
keysarray: the array of the keys of the menu items
for example: ['key4','key3']
https://github.com/aspose-cells/Aspose.Cells-for-Python-via-.NET/tree/main/Examples_GridJs_Python_Net/wwwroot/xspread/index.html のgithubデモページで詳細を確認できます