Loading...

ListView


ListView Example
Date Temp. (C) Temp. (F) Summary
2018/5/6 1 33 Freezing
2018/5/7 14 57 Bracing
2018/5/8 -13 9 Freezing
2018/5/9 -16 4 Balmy
2018/5/10 -2 29 Chilly
@inherits ControlComponent
@inject HttpClient Http

<table cellpadding="2" width="640px" border="1">
                                            <tr>
                                            <th>Date</th>
                                            <th>Temp. (C)</th>
                                            <th>Temp. (F)</th>
                                            <th>Summary</th>
                                            </tr>
                                            <asp.ListView DataSourceID="FreeDataSource1">
                                            <ItemTemplate TItem="WeatherForecast">
                                            <tr>
                                            <td>
                                            @string.Format("{0:yyyy/M/d}", context.Date)
                                            </td>
                                            <td>
                                            @context.TemperatureC
                                            </td>
                                            <td>
                                            @context.TemperatureF
                                            </td>
                                            <td>
                                            @context.Summary
                                            </td>
                                            </tr>
                                            </ItemTemplate>
                                            </asp.ListView>
</table>

<asp.FreeDataSource ID="FreeDataSource1" OnExecuteSelected="sender => this.forecasts" />

@code {
                                            private WeatherForecast[] forecasts;

                                            protected override async Task OnInitializedAsync()
    {
        forecasts = await Http.GetFromJsonAsync<WeatherForecast[]>("sample-data/weather.json");
    }

                                            public class WeatherForecast
    {
                                            public DateTime Date { get; set; }

                                            public int TemperatureC { get; set; }

                                            public string Summary { get; set; }

                                            public int TemperatureF => 32 + (int)(TemperatureC / 0.5556);
    }
}
ListView Example, to insert, delete, and update records.
CompanyName ContactName JobTitle Phone
Company A Anna Bedecs Owner (123)555-0100
Company B Antonio Gratacos Solsona Owner (123)555-0100
Company C Thomas Axen Purchasing Representative (123)555-0100
Company D Christina Lee Purchasing Manager (123)555-0100
Company E Martin O’Donnell Owner (123)555-0100
Company F Francisco Pérez-Olaeta Purchasing Manager (123)555-0100
Company G Ming-Yang Xie Owner (123)555-0100
Company H Elizabeth Andersen Purchasing Representative (123)555-0100
Company I Sven Mortensen Purchasing Manager (123)555-0100
Company J Roland Wacker Purchasing Manager (123)555-0100
@using System.Collections
@inherits ControlComponent
@inject HttpClient Http

<table cellpadding="2" border="1">
                                            <tr>
                                            <th></th>
                                            <th>CompanyName</th>
                                            <th>ContactName</th>
                                            <th>JobTitle</th>
                                            <th>Phone</th>
                                            </tr>
                                            <asp.ListView DataSourceID="CustomersSource"
                                            DataKeyNames="CustomerID"
                                            ConvertEmptyStringToNull="true"
                                            InsertItemPosition="InsertItemPosition.LastItem">
                                            <ItemTemplate TItem="Customer">
                                            <tr style="white-space: nowrap;">
                                            <td>
                                            <asp.Button Text="Select" CommandName="Select" />
                                            <asp.Button Text="Edit" CommandName="Edit" />
                                            </td>
                                            <td>
                                            @context.CompanyName
                                            </td>
                                            <td>
                                            @context.ContactName
                                            </td>
                                            <td>
                                            @context.JobTitle
                                            </td>
                                            <td>
                                            @context.Phone
                                            </td>
                                            </tr>
                                            </ItemTemplate>
                                            <SelectedItemTemplate TItem="Customer">
                                            <tr style="background-color: #9ACD32; white-space: nowrap;">
                                            <td>
                                            <asp.Button Text="Delete" CommandName="Delete" />
                                            <asp.Button Text="Edit" CommandName="Edit" />
                                            </td>
                                            <td>
                                            @context.CompanyName
                                            </td>
                                            <td>
                                            @context.ContactName
                                            </td>
                                            <td>
                                            @context.JobTitle
                                            </td>
                                            <td>
                                            @context.Phone
                                            </td>
                                            </tr>
                                            </SelectedItemTemplate>
                                            <EditItemTemplate TItem="Customer">
                                            <tr style="background-color: #8FBC8F; white-space: nowrap;">
                                            <td>
                                            <asp.Button Text="Update" CommandName="Update" />
                                            <asp.Button Text="Cancel" CommandName="Cancel" />
                                            </td>
                                            <td>
                                            <asp.TextBox @bind-Text="context.CompanyName"></asp.TextBox>
                                            </td>
                                            <td>
                                            <asp.TextBox @bind-Text="context.ContactName"></asp.TextBox>
                                            </td>
                                            <td>
                                            <asp.TextBox @bind-Text="context.JobTitle"></asp.TextBox>
                                            </td>
                                            <td>
                                            <asp.TextBox @bind-Text="context.Phone"></asp.TextBox>
                                            </td>
                                            </tr>
                                            </EditItemTemplate>
                                            <InsertItemTemplate TItem="Customer">
                                            <tr style="background-color: #FFFACD; white-space: nowrap;">
                                            <td>
                                            <asp.Button Text="Insert" CommandName="Insert" />
                                            <asp.Button Text="Cancel" CommandName="Cancel" />
                                            </td>
                                            <td>
                                            <asp.TextBox @bind-Text="context.CompanyName"></asp.TextBox>
                                            </td>
                                            <td>
                                            <asp.TextBox @bind-Text="context.ContactName"></asp.TextBox>
                                            </td>
                                            <td>
                                            <asp.TextBox @bind-Text="context.JobTitle"></asp.TextBox>
                                            </td>
                                            <td>
                                            <asp.TextBox @bind-Text="context.Phone"></asp.TextBox>
                                            </td>
                                            </tr>
                                            </InsertItemTemplate>
                                            </asp.ListView>
</table>

<asp.FreeDataSource ID="CustomersSource" OnExecuteSelected="sender => this.customers"
                                            OnExecuteInserted="this.CustomersSource_ExecuteInserted"
                                            OnExecuteUpdated="this.CustomersSource_ExecuteUpdated"
                                            OnExecuteDeleted="this.CustomersSource_ExecuteDeleted" />

@code {
                                            private Customer[] customers;

                                            protected override async Task OnInitializedAsync()
    {
        customers = await Http.GetFromJsonAsync<Customer[]>("sample-data/customers.json");
    }

                                            protected void CustomersSource_ExecuteInserted(object sender, IDictionary values)
    {
                                            // Insert record.
        Customer customer = new Customer().Apply(() => values)
            .Apply(() => new { CustomerID = customers.Max(a => a.CustomerID) + 1 });
        customers = customers.Union(new Customer[] { customer }).ToArray();
    }

                                            protected void CustomersSource_ExecuteUpdated(object sender, IDictionary keys, IDictionary values, IDictionary oldValues)
    {
                                            // Update record.
        customers.Where(a => a.CustomerID == (int)keys["CustomerID"]).Apply(a => values);
    }

                                            protected void CustomersSource_ExecuteDeleted(object sender, IDictionary keys, IDictionary oldValues)
    {
                                            // Delete record.
        customers = customers.Where(a => a.CustomerID != (int)keys["CustomerID"]).ToArray();
    }

                                            public class Customer
    {
                                            public int CustomerID { get; set; }

                                            public string CompanyName { get; set; }

                                            public string ContactName { get; set; }

                                            public string JobTitle { get; set; }

                                            public string City { get; set; }

                                            public string Address { get; set; }

                                            public string CountryRegion { get; set; }

                                            public string Phone { get; set; }

                                            public string Fax { get; set; }
    }
}

ListView Metadata
Name Type Kind
Attributes IReadOnlyDictionary Parameter
ChildLevel Int32 Parameter
ClientIDMode ClientIDMode Parameter
ClientIDRowSuffix String Parameter
ConvertEmptyStringToNull Boolean Parameter
DataKeyNames String Parameter
DataMember String Parameter
DataSourceID String Parameter
EditIndex Int32 Parameter
Enabled Boolean Parameter
EnableModelValidation Boolean Parameter
EnablePersistedSelection Boolean Parameter
GroupItemCount Int32 Parameter
GroupPlaceholderID String Parameter
ID String Parameter
InsertItemPosition InsertItemPosition Parameter
ItemPlaceholderID String Parameter
SelectedIndex Int32 Parameter
Style String Parameter
Visible Boolean Parameter
OnCallingDataMethods CallingDataMethodsEventHandler Event
OnCreatingModelDataSource CreatingModelDataSourceEventHandler Event
OnDataBinding EventHandler Event
OnDataBound EventHandler Event
OnDisposed EventHandler Event
OnInit EventHandler Event
OnItemCanceling EventHandler Event
OnItemCommand EventHandler Event
OnItemCreated EventHandler Event
OnItemDataBound EventHandler Event
OnItemDeleted EventHandler Event
OnItemDeleting EventHandler Event
OnItemEditing EventHandler Event
OnItemInserted EventHandler Event
OnItemInserting EventHandler Event
OnItemUpdated EventHandler Event
OnItemUpdating EventHandler Event
OnLayoutCreated EventHandler Event
OnLoad EventHandler Event
OnPagePropertiesChanged EventHandler Event
OnPagePropertiesChanging EventHandler Event
OnPreRender EventHandler Event
OnSelectedIndexChanged EventHandler Event
OnSelectedIndexChanging EventHandler Event
OnSorted EventHandler Event
OnSorting EventHandler Event
OnUnload EventHandler Event
TItem Type Parameter
SubstituteItem Boolean Parameter
TItem Type Parameter
TItem Type Parameter
TItem Type Parameter
TItem Type Parameter
Copyright © 2024 Jurio li All rights reserved.
An unhandled error has occurred. Reload 🗙