-
Data Grid
- Overview
-
Data Binding
-
Paging and Scrolling
-
Editing
-
Grouping
-
Filtering and Sorting
- Focused Row
-
Row Drag & Drop
-
Selection
-
Columns
- State Persistence
-
Appearance
-
Templates
-
Data Summaries
-
Master-Detail
-
Export to PDF
-
Export to Excel
-
Adaptability
- Keyboard Navigation
-
Pivot Grid
- Overview
-
Data Binding
-
Field Chooser
-
Features
-
Export to Excel
-
Tree List
- Overview
-
Data Binding
- Sorting
- Paging
-
Editing
- Node Drag & Drop
- Focused Row
-
Selection
-
Filtering
-
Column Customization
- State Persistence
- Adaptability
- Keyboard Navigation
-
Scheduler
- Overview
-
Data Binding
-
Views
-
Features
- Virtual Scrolling
-
Grouping
-
Customization
- Adaptability
-
Html Editor
-
Chat
-
Diagram
- Overview
-
Data Binding
-
Featured Shapes
-
Custom Shapes
-
Document Capabilities
-
User Interaction
- UI Customization
- Adaptability
-
Charts
- Overview
-
Data Binding
-
Area Charts
-
Bar Charts
- Bullet Charts
-
Doughnut Charts
-
Financial Charts
-
Line Charts
-
Pie Charts
-
Point Charts
-
Polar and Radar Charts
-
Range Charts
-
Sparkline Charts
-
Tree Map
-
Funnel and Pyramid Charts
- Sankey Chart
-
Combinations
-
More Features
-
Export
-
Selection
-
Tooltips
-
Zooming
-
-
Gantt
- Overview
-
Data
-
UI Customization
- Strip Lines
- Export to PDF
- Sorting
-
Filtering
-
Gauges
- Overview
-
Data Binding
-
Bar Gauge
-
Circular Gauge
-
Linear Gauge
-
Navigation
- Overview
- Accordion
-
Menu
- Multi View
-
Drawer
-
Tab Panel
-
Tabs
-
Toolbar
- Pagination
-
Tree View
- Right-to-Left Support
-
Layout
-
Editors
- Overview
- Autocomplete
-
Calendar
- Check Box
- Color Box
-
Date Box
-
Date Range Box
-
Drop Down Box
-
Number Box
-
Select Box
- Switch
-
Tag Box
- Text Area
- Text Box
- Validation
- Custom Text Editor Buttons
- Right-to-Left Support
- Editor Appearance Variants
-
Forms and Multi-Purpose
- Overview
- Button Group
- Field Set
-
Filter Builder
-
Form
- Radio Group
-
Range Selector
- Numeric Scale (Lightweight)
- Numeric Scale
- Date-Time Scale (Lightweight)
- Date-Time Scale
- Logarithmic Scale
- Discrete scale
- Custom Formatting
- Use Range Selection for Calculation
- Use Range Selection for Filtering
- Image on Background
- Chart on Background
- Customized Chart on Background
- Chart on Background with Series Template
- Range Slider
- Slider
-
Sortable
-
File Management
-
File Manager
- Overview
-
File System Types
-
Customization
-
File Uploader
-
-
Actions and Lists
- Overview
-
Action Sheet
-
Button
- Floating Action Button
- Drop Down Button
-
Context Menu
-
List
-
Lookup
-
Maps
- Overview
-
Map
-
Vector Map
-
Dialogs and Notifications
-
Localization
JavaScript/jQuery Button Group
JavaScript ButtonGroup displays a set of two-state buttons and allows users to select one or multiple buttons. This demo illustrates how to configure the JavaScript ButtonGroup in the following steps:
-
Bind JavaScript ButtonGroup to data.
-
Enable or disable multiple selection.
-
Customize the JavaScript ButtonGroup appearance.
If you have technical questions, please create a support ticket in the DevExpress Support Center.
$(() => {
$('#single-selection').dxButtonGroup({
items: alignments,
keyExpr: 'alignment',
stylingMode: 'outlined',
selectedItemKeys: ['left'],
onItemClick(e) {
DevExpress.ui.notify({ message: `The "${e.itemData.hint}" button was clicked`, width: 320 }, 'success', 1000);
},
});
$('#multiple-selection').dxButtonGroup({
items: fontStyles,
keyExpr: 'style',
stylingMode: 'outlined',
selectionMode: 'multiple',
onItemClick(e) {
DevExpress.ui.notify({ message: `The "${e.itemData.hint}" button was clicked`, width: 320 }, 'success', 1000);
},
});
$('#single-selection-styling-mode').dxButtonGroup({
items: alignments,
keyExpr: 'alignment',
stylingMode: 'text',
selectedItemKeys: ['left'],
onItemClick(e) {
DevExpress.ui.notify({ message: `The "${e.itemData.hint}" button was clicked`, width: 320 }, 'success', 1000);
},
});
$('#multiple-selection-styling-mode').dxButtonGroup({
items: fontStyles,
keyExpr: 'style',
stylingMode: 'text',
selectionMode: 'multiple',
onItemClick(e) {
DevExpress.ui.notify({ message: `The "${e.itemData.hint}" button was clicked`, width: 320 }, 'success', 1000);
},
});
});
xxxxxxxxxx
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml" lang="en">
<head>↔</head>
<body class="dx-viewport">
<div class="demo-container">
<div class="buttongroups-container">
<div id="single-selection"></div>
<div id="multiple-selection"></div>
</div>
<div class="buttongroups-container">
<div id="single-selection-styling-mode"></div>
<div id="multiple-selection-styling-mode"></div>
</div>
</div>
</body>
</html>
xxxxxxxxxx
.buttongroups-container {
display: flex;
justify-content: center;
font-size: 16px;
}
.buttongroups-container > div {
padding: 0 12px;
}
.buttongroups-container:first-child {
margin-top: 120px;
margin-bottom: 40px;
}
#multiple-selection-styling-mode {
border-left-width: 1px;
border-left-style: solid;
border-color: #ddd;
}
xxxxxxxxxx
const alignments = [
{
icon: 'alignleft',
alignment: 'left',
hint: 'Align left',
},
{
icon: 'aligncenter',
alignment: 'center',
hint: 'Center',
},
{
icon: 'alignright',
alignment: 'right',
hint: 'Align right',
},
{
icon: 'alignjustify',
alignment: 'justify',
hint: 'Justify',
},
];
const fontStyles = [
{
icon: 'bold',
style: 'bold',
hint: 'Bold',
},
{
icon: 'italic',
style: 'italic',
hint: 'Italic',
},
{
icon: 'underline',
style: 'underline',
hint: 'Underlined',
},
{
icon: 'strike',
style: 'strike',
hint: 'Strikethrough',
},
];
Bind JavaScript ButtonGroup to Data
Use the items array to populate JavaScript ButtonGroup with data. You can specify the following fields in data objects:
Process Button Selection
Set the keyExpr property to the data field that supplies keys used to distinguish the selected buttons. In this demo, the selectedItemKeys property contains the keys of the selected buttons. This property allows you to predefine selected buttons. To enable multiple selection, set the selectionMode property to multiple
.
Use the onItemClick function to process clicks on buttons.
Customize the Buttongroup Appearance
Specify the stylingMode property and select one of the three predefined styles. In this demo, the button groups in the first row have the outlined
style, while others have the text
style. You can specify the buttonTemplate property to customize the apperance of each button.
To get started with the DevExtreme JavaScript ButtonGroup component, refer to the following tutorial for step-by-step instructions: Getting Started with JavaScript ButtonGroup.