Your search did not match any results.
Tile View

Basics

Documentation
The TileView widget contains a collection of tiles. Tiles can store much more information than ordinary buttons, that is why they are very popular in apps designed for touch devices. This demo illustrates how to create a simple TileView.
Apply
Reset
<dx-tile-view class="dx-tile-content"> <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>
import { NgModule, Component } from '@angular/core'; import { BrowserModule } from '@angular/platform-browser'; import { platformBrowserDynamic } from '@angular/platform-browser-dynamic'; import { DxTileViewModule } 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 ], declarations: [AppComponent], bootstrap: [AppComponent] }) export class AppModule { } platformBrowserDynamic().bootstrapModule(AppModule);
/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@7.0.6/lib/plugin.js', 'typescript': 'npm:typescript@2.2.2/lib/typescript.js', '@angular/core': 'npm:@angular/core@4.1.0/bundles/core.umd.js', '@angular/common': 'npm:@angular/common@4.1.0/bundles/common.umd.js', '@angular/compiler': 'npm:@angular/compiler@4.1.0/bundles/compiler.umd.js', '@angular/platform-browser': 'npm:@angular/platform-browser@4.1.0/bundles/platform-browser.umd.js', '@angular/platform-browser-dynamic': 'npm:@angular/platform-browser-dynamic@4.1.0/bundles/platform-browser-dynamic.umd.js', '@angular/http': 'npm:@angular/http@4.1.0/bundles/http.umd.js', '@angular/router': 'npm:@angular/router@4.1.0/bundles/router.umd.js', '@angular/forms': 'npm:@angular/forms@4.1.0/bundles/forms.umd.js', 'rxjs': 'npm:rxjs@5.3.1', 'devextreme': 'npm:devextreme@17.1', '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@17.1' }, 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/17.1.3/css/dx.spa.css" /> <link rel="stylesheet" type="text/css" href="https://cdn3.devexpress.com/jslib/17.1.3/css/dx.common.css" /> <link rel="dx-theme" data-theme="generic.light" href="https://cdn3.devexpress.com/jslib/17.1.3/css/dx.light.css" /> <link rel="dx-theme" data-theme="android5.light" href="https://cdn3.devexpress.com/jslib/17.1.3/css/dx.android5.light.css" /> <link rel="dx-theme" data-theme="ios7.default" href="https://cdn3.devexpress.com/jslib/17.1.3/css/dx.ios7.default.css" /> <link rel="dx-theme" data-theme="win10.black" href="https://cdn3.devexpress.com/jslib/17.1.3/css/dx.win10.black.css" /> <link rel="dx-theme" data-theme="win10.white" href="https://cdn3.devexpress.com/jslib/17.1.3/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>