Your search did not match any results.
Tile View

Directions

Documentation
By default, the TileView widget is oriented horizontally, but you can orient it vertically using the direction option.
Apply
Reset
<dx-tile-view #tileView [height]="390" [baseItemHeight]="120" [baseItemWidth]="185" width="100%" [itemMargin]="10" direction="horizontal"> <dxi-item *ngFor="let home of homes" [widthRatio]="home.widthRatio" [heightRatio]="home.heightRatio"> <div class="image" [style.background-image]="'url(' + home.ImageSrc + ')'"></div> </dxi-item> </dx-tile-view> <dx-select-box [items]="['horizontal', 'vertical']" [(value)]="tileView.direction"> </dx-select-box>
import { NgModule, Component } from '@angular/core'; import { BrowserModule } from '@angular/platform-browser'; import { platformBrowserDynamic } from '@angular/platform-browser-dynamic'; import { DxTileViewModule, DxSelectBoxModule } from 'devextreme-angular'; import { Home, Service } from './app.service'; @Component({ selector: 'demo-app', templateUrl: 'app/app.component.html', styleUrls: ['app/app.component.css'], providers: [Service] }) export class AppComponent { homes: Home[]; constructor(service: Service) { this.homes = service.getHomes(); } } @NgModule({ imports: [ BrowserModule, DxTileViewModule, DxSelectBoxModule ], declarations: [AppComponent], bootstrap: [AppComponent] }) export class AppModule { } platformBrowserDynamic().bootstrapModule(AppModule);
/deep/ .dx-selectbox { margin: 10px; max-width: 400px; } /deep/ .dx-tile-content { height: 100%; } /deep/ .dx-tile-content .image { height: 100%; width: 100%; background-position: center; background-size: cover; display: block; }
import { Injectable } from '@angular/core'; export class Home { ID: string; Address: string; City: string; State: string; Price: number; ImageSrc: string; heightRatio?: number; widthRatio?: number; } let homes: Home[] = [{ ID: "1", Address: "652 Avonwick Gate", City: "Toronto", State: "ON", Price: 780000, ImageSrc: "../../../../images/gallery/1.jpg" }, { ID: "2", Address: "328 S Kerema Ave", City: "Milford", State: "CT", Price: 350000, ImageSrc: "../../../../images/gallery/3.jpg" }, { ID: "3", Address: "8512 Tanglewood Cir", City: "Reform", State: "AL", Price: 250000, ImageSrc: "../../../../images/gallery/6.jpg", widthRatio: 2 }, { ID: "4", Address: "6351 Forrest St", City: "Jersey City", State: "NJ", Price: 320000, ImageSrc: "../../../../images/gallery/14.jpg" }, { ID: "5", Address: "61207 16th St N", City: "Moorhead", State: "MN", Price: 1700000, ImageSrc: "../../../../images/gallery/5.jpg", heightRatio: 2, widthRatio: 2 }, { ID: "6", Address: "5119 Beryl Dr", City: "San Antonio", State: "TX", Price: 455000, ImageSrc: "../../../../images/gallery/4.jpg", }, { ID: "7", Address: "7121 Bailey St", City: "Worcester", State: "MA", Price: 555000, ImageSrc: "../../../../images/gallery/7.jpg", }, { ID: "8", Address: "82649 Topeka St", City: "Riverbank", State: "CA", Price: 1750000, ImageSrc: "../../../../images/gallery/2.jpg", heightRatio: 2 }, { ID: "9", Address: "7700 Elmwood Dr", City: "Cleveland", State: "OK", Price: 470000, ImageSrc: "../../../../images/gallery/17.jpg", heightRatio: 2, widthRatio: 2 }, { ID: "10", Address: "620201 Plymouth Rd", City: "Detroit", State: "MI", Price: 610000, ImageSrc: "../../../../images/gallery/8.jpg" }, { ID: "11", Address: "1198 Theresa Cir", City: "Whitinsville", State: "MA", Price: 320000, ImageSrc: "../../../../images/gallery/9.jpg" }, { ID: "12", Address: "4815 Warbler Ln", City: "Rockport", State: "TX", Price: 700000, ImageSrc: "../../../../images/gallery/12.jpg" }, { ID: "13", Address: "420234 Rogge St", City: "Detroit", State: "MI", Price: 320000, ImageSrc: "../../../../images/gallery/23.jpg" }, { ID: "14", Address: "114840 Interlake Ave N", City: "Seattle", State: "WA", Price: 400000, ImageSrc: "../../../../images/gallery/22.jpg" }, { ID: "15", Address: "13673 Pearl Dr #7", City: "Monroe", State: "MI", Price: 399000, ImageSrc: "../../../../images/gallery/20.jpg" }, { ID: "16", Address: "15447 Via Viento", City: "Atascadero", State: "CA", Price: 1100000, ImageSrc: "../../../../images/gallery/21.jpg" }]; @Injectable() export class Service { getHomes(): Home[] { return homes; } }
// In real applications, you should not transpile code in the browser. You can see how to create your own application with Angular 2 and DevExtreme here: // https://github.com/DevExpress/devextreme-angular/blob/master/README.md System.config({ transpiler: 'ts', typescriptOptions: { module: "commonjs", emitDecoratorMetadata: true, experimentalDecorators: true }, meta: { 'typescript': { "exports": "ts" } }, paths: { 'npm:': 'https://unpkg.com/' }, map: { 'ts': 'npm:plugin-typescript@4.0.10/lib/plugin.js', 'typescript': 'npm:typescript@2.0.6/lib/typescript.js', '@angular/core': 'npm:@angular/core@2.4.3/bundles/core.umd.js', '@angular/common': 'npm:@angular/common@2.4.3/bundles/common.umd.js', '@angular/compiler': 'npm:@angular/compiler@2.4.3/bundles/compiler.umd.js', '@angular/platform-browser': 'npm:@angular/platform-browser@2.4.3/bundles/platform-browser.umd.js', '@angular/platform-browser-dynamic': 'npm:@angular/platform-browser-dynamic@2.4.3/bundles/platform-browser-dynamic.umd.js', '@angular/http': 'npm:@angular/http@2.4.3/bundles/http.umd.js', '@angular/router': 'npm:@angular/router@3.4.3/bundles/router.umd.js', '@angular/forms': 'npm:@angular/forms@2.4.3/bundles/forms.umd.js', 'rxjs': 'npm:rxjs@5.0.3', 'devextreme': 'npm:devextreme@16.2', 'jquery': 'npm:jquery@3.1.1/dist/jquery.min.js', 'jszip': 'npm:jszip@3.1.3/dist/jszip.min.js', 'devextreme-angular': 'npm:devextreme-angular@16.2' }, packages: { 'app': { main: './app.component.ts', defaultExtension: 'ts' }, 'devextreme': { defaultExtension: 'js' }, 'devextreme-angular': { main: 'index.js', defaultExtension: 'js' } } });
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <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/16.2.5/css/dx.spa.css" /> <link rel="stylesheet" type="text/css" href="https://cdn3.devexpress.com/jslib/16.2.5/css/dx.common.css" /> <link rel="dx-theme" data-theme="generic.light" href="https://cdn3.devexpress.com/jslib/16.2.5/css/dx.light.css" /> <link rel="dx-theme" data-theme="android5.light" href="https://cdn3.devexpress.com/jslib/16.2.5/css/dx.android5.light.css" /> <link rel="dx-theme" data-theme="ios7.default" href="https://cdn3.devexpress.com/jslib/16.2.5/css/dx.ios7.default.css" /> <link rel="dx-theme" data-theme="win10.black" href="https://cdn3.devexpress.com/jslib/16.2.5/css/dx.win10.black.css" /> <link rel="dx-theme" data-theme="win10.white" href="https://cdn3.devexpress.com/jslib/16.2.5/css/dx.win10.white.css" /> <script src="https://unpkg.com/core-js@2.4.1/client/shim.min.js"></script> <script src="https://unpkg.com/zone.js@0.6.25/dist/zone.js"></script> <script src="https://unpkg.com/reflect-metadata@0.1.3/Reflect.js"></script> <script src="https://unpkg.com/systemjs@0.19.31/dist/system.js"></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>