Your search did not match any results.

Styling Mode

This example demonstrates editor styling modes. You can use the Styling Mode select box to change the mode.

Note that in frameworks that support property binding (Angular, AngularJS, Vue, and React), each editor’s stylingMode property is bound to a property you can change using the select box. In jQuery and ASP.NET MVC, the select box changes the global editorStylingMode property that applies the styling mode to all the editors on the page.

Copy to CodeSandBox
<div class="title">Edit Task</div> <div class="editors"> <div class="left"> <dx-text-box value="Samantha Bright" width="100%" placeholder="Owner" [stylingMode]="stylingMode" ></dx-text-box> <dx-text-box value="" width="100%" placeholder="Subject" [stylingMode]="stylingMode" > <dx-validator [validationRules]="[{ type: 'required' }]"></dx-validator> </dx-text-box> </div> <div class="right"> <dx-date-box [value]="date" width="100%" placeholder="Start Date" [stylingMode]="stylingMode" ></dx-date-box> <dx-select-box [items]="[ 'High', 'Urgent', 'Normal', 'Low' ]" value="High" width="100%" placeholder="Priority" [stylingMode]="stylingMode" ></dx-select-box> </div> <div class="center"> <dx-tag-box [items]="[ 'Not Started', 'Need Assistance', 'In Progress', 'Deferred', 'Completed' ]" [value]="[ 'Not Started' ]" [multiline]="false" width="100%" placeholder="Status" [stylingMode]="stylingMode" ></dx-tag-box> <dx-text-area value="Need sign-off on the new NDA agreement. It's important that this is done quickly to prevent any unauthorized leaks." width="100%" placeholder="Details" [stylingMode]="stylingMode" ></dx-text-area> </div> <div class="center"> <dx-button text="Save" type="default" (onClick)="validateClick($event)" class="validate" ></dx-button> </div> </div> <div class="options"> <div class="caption">Styling Mode</div> <div class="option"> <dx-select-box [items]="[ 'outlined', 'filled', 'underlined' ]" [(value)]="stylingMode" ></dx-select-box> </div> </div>
import { Component, NgModule, enableProdMode } from '@angular/core'; import { BrowserModule } from '@angular/platform-browser'; import { platformBrowserDynamic } from '@angular/platform-browser-dynamic'; import { DxSelectBoxModule, DxTextBoxModule, DxTextAreaModule, DxTagBoxModule, DxDateBoxModule, DxButtonModule, DxValidatorModule } from 'devextreme-angular'; import notify from 'devextreme/ui/notify'; import validationEngine from 'devextreme/ui/validation_engine'; if (!/localhost/.test( { enableProdMode(); } @Component({ selector: 'demo-app', providers: [], templateUrl: 'app/app.component.html', styleUrls: ['app/app.component.css'], preserveWhitespaces: true }) export class AppComponent { stylingMode = "filled"; date = new Date(2020, 4, 3); validateClick(e) { var result = e.validationGroup.validate(); if (result.isValid) { notify('The task was saved successfully.', 'success'); } else { notify('The task was not saved. Please check if all fields are valid.', 'error'); } } constructor() { setTimeout(() => validationEngine.validateGroup()); } } @NgModule({ imports: [ BrowserModule, DxSelectBoxModule, DxTextBoxModule, DxTextAreaModule, DxTagBoxModule, DxDateBoxModule, DxButtonModule, DxValidatorModule ], declarations: [AppComponent], bootstrap: [AppComponent] }) export class AppModule { } platformBrowserDynamic().bootstrapModule(AppModule);
::ng-deep .title { padding: 20px 0 20px 0; font-size: 18px; font-weight: 500; } ::ng-deep .editors { margin-right: 320px; } ::ng-deep .editors .left, ::ng-deep .editors .right { display: inline-block; width: 49%; padding-right: 20px; box-sizing: border-box; } ::ng-deep .editors .left > *, ::ng-deep .editors .right > *, ::ng-deep .editors .center > * { margin-bottom: 20px; } ::ng-deep .editors .center { padding: 20px 27px 0 0; } ::ng-deep .validate { float: right; } ::ng-deep .options { padding: 20px; position: absolute; bottom: 0; right: 0; width: 260px; top: 0; background-color: rgba(191, 191, 191, 0.15); } ::ng-deep .caption { font-size: 18px; font-weight: 500; } ::ng-deep .option { margin-top: 20px; }
// In real applications, you should not transpile code in the browser. You can see how to create your own application with Angular and DevExtreme here: // System.config({ transpiler: 'ts', typescriptOptions: { module: "system", emitDecoratorMetadata: true, experimentalDecorators: true }, meta: { 'typescript': { "exports": "ts" }, 'devextreme/localization.js': { "esModule": true } }, paths: { 'npm:': '' }, map: { 'ts': 'npm:plugin-typescript@8.0.0/lib/plugin.js', 'typescript': 'npm:typescript@3.5.3/lib/typescript.js', '@angular': 'npm:@angular', 'tslib': 'npm:tslib@2.2.0/tslib.js', 'rxjs': 'npm:rxjs@6.4.0', 'rrule': 'npm:rrule@2.6.6/dist/es5/rrule.js', 'luxon': 'npm:luxon@1.26.0/build/global/luxon.min.js', 'es6-object-assign': 'npm:es6-object-assign@1.1.0', 'devextreme': 'npm:devextreme@20.2.7', 'jszip': 'npm:jszip@3.6.0/dist/jszip.min.js', 'devextreme-quill': 'npm:devextreme-quill@0.10.3/dist/dx-quill.min.js', 'devexpress-diagram': 'npm:devexpress-diagram@2.0.23', 'devexpress-gantt': 'npm:devexpress-gantt@2.0.29', 'devextreme-angular': 'npm:devextreme-angular@20.2.6', 'preact': 'npm:preact@10.5.13/dist/preact.js', 'preact/hooks': 'npm:preact@10.5.13/hooks/dist/hooks.js' }, packages: { 'app': { main: './app.component.ts', defaultExtension: 'ts' }, 'devextreme': { defaultExtension: 'js' }, 'devextreme/events/utils': { main: 'index' }, 'devextreme/events': { main: 'index' }, 'es6-object-assign': { main: './index.js', defaultExtension: 'js' } }, packageConfigPaths: [ "npm:@angular/*/package.json", "npm:@angular/common/*/package.json", "npm:rxjs/package.json", "npm:rxjs/operators/package.json", "npm:devextreme-angular/*/package.json", "npm:devextreme-angular/ui/*/package.json", "npm:devextreme-angular/package.json", "npm:devexpress-diagram/package.json", "npm:devexpress-gantt/package.json", ] });
<!DOCTYPE html> <html xmlns=""> <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="" /> <link rel="stylesheet" type="text/css" href="" /> <script src=""></script> <script src=""></script> <script src=""></script> <script src=""></script> <script src="config.js"></script> <script> System.import('app').catch(console.error.bind(console)); </script> </head> <body class="dx-viewport"> <div class="demo-container"> <demo-app>Loading...</demo-app> </div> </body> </html>