Search results

Set title for Menu items in React Menu Bar component

In this sample , the title for menu item can be achievable by using ‘beforeItemRender’ client-side event in Menu component.

Source
Preview
index.jsx
index.tsx
index.html
import { enableRipple } from '@syncfusion/ej2-base';
import { MenuComponent } from '@syncfusion/ej2-react-navigations';
import * as React from 'react';
import * as ReactDom from 'react-dom';
enableRipple(true);
class App extends React.Component {
    constructor(props) {
        super(props);
        this.menuItems = [
            {
                id: 'settingIcon',
                iconCss: 'em-icons e-file',
                items: [
                    { text: 'Open',
                        items: [
                            { text: 'Sub Option1' },
                            { text: 'Sub Option2' },
                        ]
                    },
                    { text: 'Save' },
                    { separator: true },
                    { text: 'Exit' }
                ]
            }
        ];
        this.beforeItemRender = this.beforeItemRender.bind(this);
    }
    beforeItemRender(args) {
        if (args.item.id == 'settingIcon') {
            args.element.setAttribute('title', 'Settings');
        }
    }
    render() {
        return (<MenuComponent items={this.menuItems} beforeItemRender={this.beforeItemRender}/>);
    }
}
ReactDom.render(<App />, document.getElementById('element'));
import { enableRipple } from '@syncfusion/ej2-base';
import { ButtonComponent } from '@syncfusion/ej2-react-buttons';
import { MenuComponent, MenuEventArgs, MenuItemModel } from '@syncfusion/ej2-react-navigations';
import * as React from 'react';
import * as ReactDom from 'react-dom';
enableRipple(true);

class App extends React.Component<{}, {}> {
    public menuItems: MenuItemModel[] = [
        {
            id: 'settingIcon',
            iconCss: 'em-icons e-file',
            items: [
                { text: 'Open',
                  items: [
                      { text: 'Sub Option1' },
                      { text: 'Sub Option2' },
                  ]
                },
                { text: 'Save' },
                { separator: true },
                { text: 'Exit' }
            ]
        }
    ];
    constructor(props: any) {
        super(props);
        this.beforeItemRender = this.beforeItemRender.bind(this);
    }

    public beforeItemRender(args: MenuEventArgs): void {
        if (args.item.id == 'settingIcon') {
        args.element.setAttribute('title', 'Settings');
      }
    }

    public render() {
        return (
            <MenuComponent items={this.menuItems}  beforeItemRender={this.beforeItemRender}/>
        );
    }
}

ReactDom.render(<App />,document.getElementById('element'));
<!DOCTYPE html>
<html lang="en">

<head>
    <title>Syncfusion React ContextMenu</title>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <meta name="description" content="Essential JS 2 for React Components" />
    <meta name="author" content="Syncfusion" />
    <link href="//cdn.syncfusion.com/ej2/ej2-base/styles/material.css" rel="stylesheet" />
    <link href="//cdn.syncfusion.com/ej2/ej2-buttons/styles/material.css" rel="stylesheet" />
    <link href="//cdn.syncfusion.com/ej2/ej2-popups/styles/material.css" rel="stylesheet" />
    <link href="//cdn.syncfusion.com/ej2/ej2-navigations/styles/material.css" rel="stylesheet" />
    <link href="//cdn.syncfusion.com/ej2/ej2-cards/styles/material.css" rel="stylesheet" />
    <link href="//cdn.syncfusion.com/ej2/ej2-notifications/styles/material.css" rel="stylesheet" />
    <link href="//cdn.syncfusion.com/ej2/ej2-layouts/styles/material.css" rel="stylesheet" />
    <link href="index.css" rel="stylesheet" />
    <script src="https://cdnjs.cloudflare.com/ajax/libs/systemjs/0.19.38/system.js"></script>
    <script src="systemjs.config.js"></script>
</head>

<body>
    <div id='element'>
        <div id='loader'>Loading....</div>
    </div>
</body>

</html>