Your search did not match any results.
Form

Grouped Fields

Documentation

This demo illustrates how to organize Form items into groups and tabbed pages. For this purpose, an array containing «group» and «tabbed» items is passed to the items option.

Copy to CodeSandBox
Apply
Reset
import React from 'react'; import 'devextreme-react/text-area'; import Form, { Item } from 'devextreme-react/form'; import service from './data.js'; class App extends React.Component { constructor(props) { super(props); this.employee = service.getEmployee(); this.groupedItems = { systemInformation: [ 'ID', 'FirstName', 'LastName', 'HireDate', 'Position', 'OfficeNo' ], personalData: [ 'BirthDate', { itemType: 'group', caption: 'Home Address', items: ['Address', 'City', 'State', 'Zipcode'] } ], contactInformation: [{ itemType: 'tabbed', tabPanelOptions: { deferRendering: false }, tabs: [{ title: 'Phone', items: ['Phone'] }, { title: 'Skype', items: ['Skype'] }, { title: 'Email', items: ['Email'] }] } ] }; } render() { return ( <React.Fragment> <div className={'long-title'}><h3>Personal details</h3></div> <div className={'form-container'}> <Form colCount={2} id={'form'} formData={this.employee}> <Item itemType={'group'} caption={'System Information'} items={this.groupedItems.systemInformation} /> <Item itemType={'group'} caption={'Personal Data'} items={this.groupedItems.personalData} /> <Item itemType={'group'} caption={'Contact Information'} items={this.groupedItems.contactInformation} /> </Form> </div> </React.Fragment> ); } } export default App;
import React from 'react'; import ReactDOM from 'react-dom'; import App from './App.js'; ReactDOM.render( <App />, document.getElementById('app') );
<!DOCTYPE html> <html> <head> <title>DevExtreme Demo</title> <meta http-equiv="X-UA-Compatible" content="IE=edge" /> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0" /> <link rel="stylesheet" type="text/css" href="https://cdn3.devexpress.com/jslib/19.1.7/css/dx.common.css" /> <link rel="stylesheet" type="text/css" href="https://cdn3.devexpress.com/jslib/19.1.7/css/dx.light.css" /> <link rel="stylesheet" type="text/css" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.6.3/css/font-awesome.min.css" /> <link rel="stylesheet" type="text/css" href="styles.css" /> <script src="https://unpkg.com/core-js@2.4.1/client/shim.min.js"></script> <script src="https://unpkg.com/systemjs@0.21.3/dist/system.js"></script> <script type="text/javascript" src="config.js"></script> <script type="text/javascript"> System.import('./index.js'); </script> </head> <body class="dx-viewport"> <div class="demo-container"> <div id="app"></div> </div> </body> </html>
.form-container { margin: 10px; } .long-title h3 { font-family: 'Segoe UI Light', 'Helvetica Neue Light', 'Segoe UI', 'Helvetica Neue', 'Trebuchet MS', Verdana; font-weight: 200; font-size: 28px; text-align: center; margin-bottom: 20px; }
const employee = { 'ID': 1, 'FirstName': 'John', 'LastName': 'Heart', 'CompanyName': 'Super Mart of the West', 'Position': 'CEO', 'OfficeNo': '901', 'BirthDate': new Date(1964, 2, 16), 'HireDate': new Date(1995, 0, 15), 'Address': '351 S Hill St.', 'City': 'Los Angeles', 'State': 'CA', 'Zipcode': '90013', 'Phone': '+1(213) 555-9392', 'Email': 'jheart@dx-email.com', 'Skype': 'jheart_DX_skype' }; export default { getEmployee() { return employee; } };
System.config({ transpiler: 'plugin-babel', paths: { 'npm:': 'https://unpkg.com/' }, defaultExtension: 'js', map: { 'react': 'npm:react@16/umd/react.development.js', 'react-dom': 'npm:react-dom@16/umd/react-dom.development.js', 'prop-types': 'npm:prop-types/prop-types.js', 'devextreme': 'npm:devextreme@18.2', 'devextreme-react': 'npm:devextreme-react@18.2', 'jszip': 'npm:jszip@3.1.3/dist/jszip.min.js', 'quill': 'npm:quill@1.3.7/dist/quill.js', 'devexpress-diagram': 'npm:devexpress-diagram', // SystemJS plugins 'plugin-babel': 'npm:systemjs-plugin-babel@0/plugin-babel.js', 'systemjs-babel-build': 'npm:systemjs-plugin-babel@0/systemjs-babel-browser.js' }, packages: { 'devextreme': { defaultExtension: 'js' }, 'devextreme-react': { main: 'index.js' } }, babelOptions: { sourceMaps: false, stage0: true, react: true } });