Data Binding

Toolbar provides you a flexible approach for binding data from various data sources. There are various properties in Toolbar for Data Binding.

Data fields and configuration

The following sub-properties provides a way to bind either the local/remote data to the Toolbar control.

Property Table of Toolbar control

Property Value type Description
Datasource object It specifies the data source of the Toolbar. The data source contains the list of data for generating the Toolbar items.
Fields object It specifies the mapping fields for the data items of the Toolbar.
Id string It specifies the id of the element
Text string It specifies the text content of the element.
ImageUrl string This property defines the imageURL for the image location. While setting images, the folder name in which the images are stored should be set to imageUrl property.
ImageAttributes string This property defines style for the image. While setting an image, styles can be applied such as height, width by using this property.
SpriteCssClass string This property sets the Sprite CSS for the image element in Toolbar.
HtmlAttributes object This property sets the HTML attribute for the Toolbar item. It can be any HTML attribute such as id, class, style.
TooltipText string This property sets the text value for Toolbar item while mouse over in Toolbar.
Query object It specifies the query to retrieve the data from online server.
Group string It groups the given Toolbar items.

Local data

To bind the Local Data to the Toolbar control, map the user-defined JSON data names with its appropriate data source field. You can bind data to Toolbar by mapping fields such as Id, SpriteCssClass, ImageUrl, group and TooltipText.

The following steps explain how you can bind local data to Toolbar Control.

In the View page, add Toolbar helper to configure Toolbar.

  • cshtml
  • // Add this code in your CSHTML page and refer local data section for data source
    
    <ej-toolbar id="toolbar" dataSource="ViewBag.datasource">
        <e-toolbar-fields id="iconid" sprite-css-class="spriteCss">
    </ej-toolbar>
  • c#
  • public class ToolbarLocalBinding
    {
    	public string iconid { get; set; }
    	public string spriteCss { get; set; }
    }
    public IActionResult Index()
    {
    	List<ToolbarLocalBinding> t = new List<ToolbarLocalBinding>();
    
    	t.Add(new ToolbarLocalBinding { iconid = "1", spriteCss = "mailtools movetofolder" });
    	t.Add(new ToolbarLocalBinding { iconid = "2", spriteCss = "mailtools categorize" });
    	t.Add(new ToolbarLocalBinding { iconid = "3", spriteCss = "mailtools flag" });
    	t.Add(new ToolbarLocalBinding { iconid = "4", spriteCss = "mailtools forward" });
    	t.Add(new ToolbarLocalBinding { iconid = "5", spriteCss = "mailtools newmail" });
    	ViewBag.datasource = t;
    	return View();
    }
  • css
  • <style type="text/css" class="cssStyles">
    	.e-tooltxt .mailtools {
            background-image: url('../Content/images/maild.png');
        }
        .e-tooltxt .mailtools {
            display: block;
            background-image: url('../Content/images/maill.png');
            height: 24px;
            width: 24px;
            background-repeat: no-repeat;
        }
        .e-tooltxt:hover .mailtools, .darktheme .cols-sample-area .e-tooltxt:hover .mailtools {
            background-image: url('../Content/images/mailh.png');
        }
        .mailtools.movetofolder {
            background-position: -12px -40px;
        }
        .mailtools.categorize {
            background-position: -14px -248px;
        }
        .mailtools.flag {
            background-position: -13px -282px;
        }
        .mailtools.forward {
            background-position: -14px -314px;
        }
        .mailtools.newmail {
            background-position: -14px -348px;
        }
        .frame {
            height: 280px;
            width: 695px;
            border-radius: none;
            margin-left: 0;
            margin-top: 40px;
            padding: 0;
        }
        .control {
            margin: 120px 200px 0;
        }
    </style>

    ToolBar control bounded to Local Data

    Remote data

    You can bind Toolbar to Remote Data using DataManager and the query in fields is used to retrieve the data. DataManager supports the following types of data-binding: JSON, Web Services and OData. It uses two different classes; ej.DataManager for processing, and ej.Query for serving data. ej.DataManager communicates with data source and ej.Query generates data queries that are read by the DataManager.

    The following steps explain how you can bind remote data to Toolbar control.

    1. In the View page, add Toolbar helper to configure Toolbar.
  • cshtml
  • <ej-toolbar id="toolbarOdata" width="300px" query="ej.Query().from('Orders').take(6)">
        <e-toolbar-fields text="CustomerID" />
        <e-datamanager url="//mvc.syncfusion.com/Services/Northwnd.svc/"></e-datamanager>
    </ej-toolbar>

    ToolBar control bounded to Remote Data