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
<template> <div> <div class="long-title"><h3>Personal details</h3></div> <div id="form-container"> <dx-form id="form" :col-count="2" :form-data="employee" > <dx-item :items="groupedItems.systemInformation" item-type="group" caption="System Information" /> <dx-item :items="groupedItems.personalData" item-type="group" caption="Personal Data" /> <dx-item :items="groupedItems.contactInformation" item-type="group" caption="Contact Information" /> </dx-form> </div> </div> </template> <script> import { DxForm, DxItem } from 'devextreme-vue/form'; import service from './data.js'; import 'devextreme-vue/text-area'; export default { components: { DxForm, DxItem }, data() { const employee = service.getEmployee(); return { employee, 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'] }] } ] } }; } }; </script> <style scoped> #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; } </style>
import Vue from 'vue'; import App from './App.vue'; new Vue({ el: '#app', components: { App }, template: '<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.4/css/dx.common.css" /> <link rel="stylesheet" type="text/css" href="https://cdn3.devexpress.com/jslib/19.1.4/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" /> <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"> <span v-if="false">Loading...</span> </div> </div> </body> </html>
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/' }, map: { vue: 'npm:vue@2.6.3/dist/vue.esm.browser.js', 'vue-loader': 'npm:systemjs-vue-browser@latest/index.js', 'devextreme': 'npm:devextreme@18.2', 'devextreme-vue': 'npm:devextreme-vue@18.2', jszip: 'npm:jszip@3.1.3/dist/jszip.min.js', 'quill': 'npm:quill@1.3.6/dist/quill.js', 'devexpress-diagram': 'npm:devexpress-diagram', 'plugin-babel': 'npm:systemjs-plugin-babel@0/plugin-babel.js', 'systemjs-babel-build': 'npm:systemjs-plugin-babel@0/systemjs-babel-browser.js' }, meta: { '*.vue': { loader: 'vue-loader' } }, packages: { 'devextreme-vue': { main: 'index.js' }, 'devextreme': { defaultExtension: 'js' } }, babelOptions: { sourceMaps: false, stage0: true } });