Row Spanning

24 Feb 202217 minutes to read

The grid has option to span row cells. To achieve this, You need to define the rowSpan attribute to span cells in the queryCellInfo event.

In the following demo, Davolio cell is spanned to two rows in the EmployeeName column.

Also Grid supports the spanning of rows and columns for same cells. Lunch Break cell is spanned to two rows and three columns in the 1:00 column.

<ejs-grid id="Grid" dataSource="@ViewBag.DataSource" queryCellInfo="QueryCellEvent" gridLines="Both" allowPaging="true">
    <e-grid-columns>
        <e-grid-column field="EmployeeID" headerText="Employee ID" isPrimaryKey="true"  textAlign="Right" width="150"></e-grid-column>
        <e-grid-column field="EmployeeName" headerText="Employee Name" width="200"></e-grid-column>
        <e-grid-column field="Time900" headerText="9.00 AM" width="120"></e-grid-column>
        <e-grid-column field="Time930" headerText="9.30 AM" width="120"></e-grid-column>
        <e-grid-column field="Time1000" headerText="10.00 AM" width="120"></e-grid-column>
        <e-grid-column field="Time1030" headerText="10.30 AM" width="120"></e-grid-column>
        <e-grid-column field="Time1100" headerText="11.00 AM" width="120"></e-grid-column>
        <e-grid-column field="Time1130" headerText="11.30 AM" width="120"></e-grid-column>
        <e-grid-column field="Time1200" headerText="12.00 AM" width="120"></e-grid-column>
        <e-grid-column field="Time1230" headerText="12.30 AM" width="120"></e-grid-column>
        <e-grid-column field="Time100" headerText="1.00 PM" width="120"></e-grid-column>
        <e-grid-column field="Time130" headerText="1.30 PM" width="120"></e-grid-column>
        <e-grid-column field="Time200" headerText="2.00 PM" width="120"></e-grid-column>
        <e-grid-column field="Time230" headerText="2.30 PM" width="120"></e-grid-column>
        <e-grid-column field="Time300" headerText="3.00 PM" width="120"></e-grid-column>
        <e-grid-column field="Time330" headerText="3.30 PM" width="120"></e-grid-column>
        <e-grid-column field="Time400" headerText="4.00 PM" width="120"></e-grid-column>
        <e-grid-column field="Time430" headerText="4.30 PM" width="120"></e-grid-column>
        <e-grid-column field="Time500" headerText="5.00 PM" width="120"></e-grid-column>
    </e-grid-columns>          
</ejs-grid>
<script>
 function QueryCellEvent(args)
        {
            var data = args.data;
            switch (data.EmployeeID) {
                case 10001:
                    if (args.column.field === '9:00' || args.column.field === '2:30' || args.column.field === '4:30') {
                        args.colSpan = 2;
                    } else if (args.column.field === '11:00') {
                        args.colSpan = 3;
                    } else if (args.column.field === 'EmployeeName') {
                        args.rowSpan = 2;
                    } else if (args.column.field === '1:00') {
                        args.colSpan = 3;
                        args.rowSpan = 2;
                    }
                    break;
                case 10002:
                    if (args.column.field === '9:30' || args.column.field === '2:30' ||
                        args.column.field === '4:30') {
                        args.colSpan = 3;
                    } else if (args.column.field === '11:00') {
                        args.colSpan = 4;
                    }
                    break;
                case 10003:
                    if (args.column.field === '9:00' || args.column.field === '11:30') {
                        args.colSpan = 3;
                    } else if (args.column.field === '10:30' || args.column.field === '3:30' ||
                        args.column.field === '4:30' || args.column.field === '2:30') {
                        args.colSpan = 2;
                    }
                    break;
                case 10004:
                    if (args.column.field === '9:00') {
                        args.colSpan = 3;
                    } else if (args.column.field === '11:00') {
                        args.colSpan = 4;
                    } else if (args.column.field === '4:00' || args.column.field === '2:30') {
                        args.colSpan = 2;
                    }
                    break;
                case 10005:
                    if (args.column.field === '9:00') {
                        args.colSpan = 4;
                    } else if (args.column.field === '11:30') {
                        args.colSpan = 3;
                    } else if (args.column.field === '3:30' || args.column.field === '4:30' || args.column.field === '2:30') {
                        args.colSpan = 2;
                    }
                    break;
                case 10006:
                    if (args.column.field === '9:00' || args.column.field === '4:30' ||
                        args.column.field === '2:30' || args.column.field === '3:30') {
                        args.colSpan = 2;
                    } else if (args.column.field === '10:00' || args.column.field === '11:30') {
                        args.colSpan = 3;
                    }
                    break;
                case 10007:
                    if (args.column.field === '9:00' || args.column.field === '3:00' || args.column.field === '10:30') {
                        args.colSpan = 2;
                    } else if (args.column.field === '11:30' || args.column.field === '4:00') {
                        args.colSpan = 3;
                    }
                    break;
                case 10008:
                    if (args.column.field === '9:00' || args.column.field === '10:30' || args.column.field === '2:30') {
                        args.colSpan = 3;
                    } else if (args.column.field === '4:00') {
                        args.colSpan = 2;
                    }
                    break;
                case 10009:
                    if (args.column.field === '9:00' || args.column.field === '11:30') {
                        args.colSpan = 3;
                    } else if (args.column.field === '4:30' || args.column.field === '2:30') {
                        args.colSpan = 2;
                    }
                    break;
                case 100010:
                    if (args.column.field === '9:00' || args.column.field === '2:30' ||
                        args.column.field === '4:00' || args.column.field === '11:30') {
                        args.colSpan = 3;
                    } else if (args.column.field === '10:30') {
                        args.colSpan = 2;
                    }
                    break;
                }
         }
</script>
public IActionResult Index()
{
    ViewBag.DataSource = Merge.GetAllRecords()
    return View();
}
  • To disable the spanning for particular grid page, we need to use requestType from queryCellInfo event argument.