- 
                            Data Grids / Data Management- 
                Data Grid- Overview
- 
                Data Binding
- 
                Filtering
- Sorting
- 
                Editing
- 
                Grouping
- 
                Selection
- Focused Row
- Paging
- 
                Scrolling
- 
                Columns
- 
                Master-Detail
- 
                Data Summaries
- 
                Drag & Drop
- 
                Export to PDF
- 
                Export to Excel
- Appearance
- 
                Customization
- State Persistence
- 
                Adaptability
- 
                Keyboard Navigation
- Right-To-Left Support
 
- 
                Tree List- Overview
- 
                Data Binding
- 
                Filtering
- Sorting
- 
                Editing
- 
                Selection
- Focused Row
- Paging
- 
                Columns
- Drag & Drop
- State Persistence
- Adaptability
- 
                Keyboard Navigation
 
- 
                Card View
- 
                Pivot Grid- Overview
- 
                Data Binding
- 
                Field Management
- 
                Data Summaries
- Drill Down
- Filtering
- 
                Scrolling
- 
                Export to Excel
- Chart Integration
- Customization
- State Persistence
 
- 
                Filter Builder
 
- 
                
- 
                            Data Visualization- 
                Charts- Overview
- 
                Data Binding
- 
                Common Concepts- 
                Axis
- 
                Aggregation
- 
                Tooltips
- 
                Selection
- 
                Customization
- 
                Zooming
- 
                Export
 
- 
                
- 
                Area Charts
- 
                Bar Charts
- Bullet Charts
- 
                Doughnut Charts
- 
                Financial Charts
- 
                Funnel and Pyramid Charts
- 
                Line Charts
- Pareto Chart
- 
                Pie Charts
- 
                Point Charts
- 
                Polar and Radar Charts
- 
                Range Charts
- Sankey Chart
- 
                Sparkline Charts
- 
                Tree Map
 
- 
                Gauges- Overview
- 
                Runtime update
- 
                Bar Gauge
- 
                Circular Gauge
- 
                Linear Gauge
 
- 
                Diagram- Overview
- 
                Data Binding
- 
                Featured Shapes
- 
                Custom Shapes
- 
                Document Capabilities
- 
                User Interaction
- UI Customization
- Adaptability
 
 
- 
                
- 
                            Scheduling / Planning- 
                Scheduler- Overview
- 
                Data Binding
- 
                Views
- 
                Appointments
- 
                Timetable
- Editing
- 
                Grouping
- Virtual Scrolling
- Drag & Drop
- 
                Customization
- Adaptability
 
- 
                Gantt- Overview
- Data Binding
- 
                Filtering
- Sorting
- Strip Lines
- Export to PDF
- Validation
- 
                Customization
 
 
- 
                
- 
                            Reporting- 
                AI-powered Extensions
- 
                Interaction
- 
                Report Types
- 
                Data binding
- 
                Real-life Reports
- 
                Layout Features
- 
                Report Controls
- 
                Web-specific Features
 
- 
                
- 
                            Rich Text Editor- Overview
- Load/Save
- Document Protection
- 
                Templates
- Autocorrect
- 
                Customization
- Simple View
 
- 
                            Spreadsheet- Overview
- 
                Open a Document
- Export And Printing
- 
                Features
- 
                UI Customization
 
- 
                            Messaging
- 
                            WYSIWYG Editor
- 
                            Forms
- 
                            Data Editors- Overview
- 
                Common Concepts
- 
                Calendar
- Check Box
- Color Box
- Date Box
- 
                Date Range Box
- 
                Number Box
- Radio Group
- 
                Range Selector
- Range Slider
- Slider
- Speech To Text
- Switch
- Text Area
- Text Box
 
- 
                            Drop-Downs- Autocomplete
- 
                Drop Down Box
- 
                Select Box
- 
                Tag Box
- 
                Lookup
 
- 
                            Buttons
- 
                            File Upload / File Management- 
                File Manager- Overview
- 
                File System Types
- 
                Customization
 
- 
                File Uploader
 
- 
                
- 
                            Popup and Notifications
- 
                            Navigation- Overview
- Accordion
- 
                Context Menu
- 
                Menu
- Multi View
- 
                Drawer
- 
                Tab Panel
- 
                Tabs
- 
                Toolbar
- 
                Stepper
- Pagination
- 
                List
- 
                Tree View
- Right-to-Left Support
 
- 
                            Layout- 
                Tile View
- Splitter
- 
                Gallery
- Scroll View
 
- 
                
- 
                            Interactive Wrappers- 
                Sortable
- Resizable
 
- 
                
- 
                            Progress Indicators
- 
                            Maps- Overview
- 
                Map
- 
                Vector Map- 
                Data Binding
- Multiple Layers
- 
                Markers
- Legend
- 
                Zooming and Panning
- 
                Customization
 
- 
                
 
- 
                            Localization
Related Demos:
        
            Your search did not match any results.
        
    Card View - Card Template
Card templates allow you to display custom card content. This demo uses a cardTemplate to display car images, car info, and a custom button within cards.
            
            Backend API
        
    @model IEnumerable<DevExtreme.NETCore.Demos.Models.Vehicle>
@(Html.DevExtreme().CardView()
    .DataSource(Model)
    .Height(1120)
    .DataSource(Model, "ID")
    .CardsPerRow(Mode.Auto)
    .CardMinWidth(240)
    .Paging(p => p.PageSize(12))
    .SearchPanel(sp => sp.Visible(true))
    .HeaderFilter(hf => hf.Visible(true))
    .Columns(c => {
        c.Add()
            .DataField("TrademarkName")
            .Caption("Trademark");
        c.Add()
            .DataField("Name")
            .Caption("Model");
        c.Add().DataField("Price")
            .Format("currency")
            .HeaderFilter(hf => {
                hf.GroupInterval(20000);
            });
        c.Add()
            .DataField("CategoryName")
            .Caption("Category");
        c.Add().DataField("Modification");
        c.Add()
            .DataField("BodyStyleName")
            .Caption("Body Style");
        c.Add().DataField("Horsepower");
    })
    .CardTemplate(@<text>
    <div class="vehicle__card">
        <div class="vehicle__img-wrapper">
            <img class="vehicle__img"
                src="@Url.Content("~/images/vehicles/image_")<%- card.data.ID %>.png"
                alt="<%- card.data.TrademarkName %> <%- card.data.Name %>" />
        </div>
        <div class="vehicle__info">
            <div class="vehicle__name" title="<%- card.data.TrademarkName %> <%- card.data.Name %>">
                <%- card.data.TrademarkName %> <%- card.data.Name %>
            </div>
            <div class="vehicle__price">
                <%- card.fields.find(f => f?.column?.dataField === 'Price').text %>
            </div>
            <div class="vehicle__type-container">
                <div class="vehicle__type">
                    <%- card.data.CategoryName %>
                </div>
            </div>
            <div class="vehicle__spec-container">
                <div class="vehicle__modification">
                    <%- card.data.Modification %>
                </div>
                <div class="vehicle__modification">
                    <%- card.data.BodyStyleName %>
                </div>
                <div class="vehicle__modification">
                    <%- card.data.Horsepower %> h.p.
                </div>
            </div>
            <div class="vehicle__footer-container">
                @(Html.DevExtreme().Button()
                .Text("Image Info")
                .Type(ButtonType.Default)
                .Width("100%")
                .OnClick("(e) => { button_onClick(e, card.data); }")
                )
            </div>
        </div>
    </div>
</text>)
)
@(Html.DevExtreme().Popup()
    .ID("vehiclePopup")
    .Width(360)
    .Height(260)
    .Title("Image Info")
    .HideOnOutsideClick(true)
    .Visible(false)
    .DragEnabled(false)
)
<script>
    const popupContentTemplate = function(vehicle) {
        const sourceLink = `https://${vehicle.Source}`;
        return $('<div>').append(
            $('<p>')
                .append($('<b>').text('Image licensed under: '))
                .append($('<span>').text(vehicle.LicenseName)),
            $('<p>')
                .append($('<b>').text('Author: '))
                .append($('<span>').text(vehicle.Author)),
            $('<p>')
                .append($('<b>').text('Source link: '))
                .append(
                    $('<a>', {
                        href: sourceLink,
                        target: '_blank',
                    })
                        .text(sourceLink),
                ),
            $('<p>')
                .append($('<b>').text('Edits: '))
                .append($('<span>').text(vehicle.Edits)),
        );
    };
    function button_onClick(e, vehicle) {
        const popup = $("#vehiclePopup").dxPopup("instance");
        popup.option('contentTemplate', popupContentTemplate(vehicle));
        popup.show();
    }
</script>
        
        using Microsoft.AspNetCore.Mvc;
using DevExtreme.NETCore.Demos.Models.CardView.ColumnChooser;
using DevExtreme.NETCore.Demos.Models.CardView.ColumnHeaderFilter;
using DevExtreme.NETCore.Demos.Models.CardView.ColumnReordering;
using DevExtreme.NETCore.Demos.Models.CardView.DataValidation;
using DevExtreme.NETCore.Demos.Models.CardView.FilterPanel;
using DevExtreme.NETCore.Demos.Models.CardView.Overview;
using DevExtreme.NETCore.Demos.Models.CardView.PopupEditing;
using DevExtreme.NETCore.Demos.Models.CardView.SearchPanel;
using DevExtreme.NETCore.Demos.Models.CardView.Selection;
using DevExtreme.NETCore.Demos.Models.CardView.SimpleArray;
using DevExtreme.NETCore.Demos.Models.CardView.Sorting;
using DevExtreme.NETCore.Demos.Models.SampleData;
namespace DevExtreme.NETCore.Demos.Controllers {
  public class CardViewController : Controller {
    public ActionResult CardTemplate() {
      return View(SampleData.Vehicles);
    }
  }
}
        
        .vehicle__img-wrapper {
    overflow: hidden;
    display: flex;
    justify-content: center;
    aspect-ratio: 16 / 9;
    width: 100%;
    background-color: #fff;
}
.vehicle__img {
    height: 100%;
    width: 100%;
    object-fit: scale-down;
}
.vehicle__info {
    padding: 12px;
    border-top: var(--dx-border-width) solid var(--dx-color-border);
}
.vehicle__name {
    font-weight: 700;
    font-size: 20px;
    line-height: 28px;
    height: 28px;
    padding-left: 12px;
    padding-right: 12px;
    text-overflow: ellipsis;
    overflow: hidden;
    white-space: nowrap;
}
.vehicle__price {
    padding-left: 12px;
    padding-right: 12px;
    height: 32px;
    font-weight: 700;
    font-size: 24px;
    color: var(--dx-color-primary);
}
.vehicle__type-container {
    padding: 12px;
    display: inline-block;
}
.vehicle__type {
    padding: 2px 6px;
    background-color: var(--dx-color-separator);
    border-radius: 13px;
}
.vehicle__spec {
    padding: 2px 12px;
}
.vehicle__modification {
    height: 24px;
    padding: 2px 0 2px 12px;
}
.vehicle__footer-container {
    padding: 12px;
}
.vehicle__image-licence-caption {
    font-weight: 600;
}