Perform (Create, Read, Update, and Delete) operations on a ListView in .Net Maui

Ronald Rex 1,666 Reputation points
2023-03-24T17:03:06.4733333+00:00

Hi Friends. I have a ListView in a Content Page that I would like the user to be able to Perform (Create, Read, Update, and Delete) operations on in .Net Maui. Thanks in advance for for any help.

.NET MAUI
.NET MAUI
A Microsoft open-source framework for building native device applications spanning mobile, tablet, and desktop.
3,390 questions
C#
C#
An object-oriented and type-safe programming language that has its roots in the C family of languages and includes support for component-oriented programming.
10,827 questions
XAML
XAML
A language based on Extensible Markup Language (XML) that enables developers to specify a hierarchy of objects with a set of properties and logic.
800 questions
{count} votes

Accepted answer
  1. Sedat SALMAN 13,740 Reputation points
    2023-03-24T20:35:42.71+00:00

    Create a new .NET MAUI

    item.cs

    
    public class Item
    {
        public int Id { get; set; }
        public string Name { get; set; }
    }
    
    

    Create a ViewModel

    public class ItemViewModel : INotifyPropertyChanged
    {
        public ObservableCollection<Item> Items { get; set; } = new ObservableCollection<Item>();
    
        public event PropertyChangedEventHandler PropertyChanged;
    
        public ItemViewModel()
        {
            // Add sample data
            Items.Add(new Item { Id = 1, Name = "Item 1" });
            Items.Add(new Item { Id = 2, Name = "Item 2" });
            Items.Add(new Item { Id = 3, Name = "Item 3" });
        }
    
        // Add an item
        public void AddItem(string name)
        {
            int id = Items.Count + 1;
            Items.Add(new Item { Id = id, Name = name });
        }
    
        // Update an item
        public void UpdateItem(int id, string name)
        {
            var item = Items.FirstOrDefault(i => i.Id == id);
            if (item != null)
            {
                item.Name = name;
                PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(nameof(Items)));
            }
        }
    
        // Delete an item
        public void DeleteItem(int id)
        {
            var item = Items.FirstOrDefault(i => i.Id == id);
            if (item != null)
            {
                Items.Remove(item);
            }
        }
    }
    
    
    1. Create the MainPage.xaml:
    
    <ContentPage xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
                 xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
                 x:Class="MauiApp.MainPage"
                 BackgroundColor="{DynamicResource PageBackgroundColor}">
    
        <Grid>
            <Grid.RowDefinitions>
                <RowDefinition Height="Auto"/>
                <RowDefinition Height="*"/>
            </Grid.RowDefinitions>
    
            <Button Text="Add Item" Clicked="OnAddItemClicked" />
    
            <ListView x:Name="ItemsListView"
                      Grid.Row="1"
                      ItemsSource="{Binding Items}"
                      SelectionMode="Single"
                      ItemSelected="OnItemSelected">
                <ListView.ItemTemplate>
                    <DataTemplate>
                        <TextCell Text="{Binding Name}" />
                    </DataTemplate>
                </ListView.ItemTemplate>
            </ListView>
        </Grid>
    </ContentPage>
    
    
    1. Update MainPage.xaml.cs:
    
    public partial class MainPage : ContentPage
    {
        private ItemViewModel _viewModel;
    
        public MainPage()
        {
            InitializeComponent();
    
            _viewModel = new ItemViewModel();
            BindingContext = _viewModel;
        }
    
        private void OnAddItemClicked(object sender, EventArgs e)
        {
            _viewModel.AddItem($"Item {_viewModel.Items.Count + 1}");
        }
    
        private async void OnItemSelected(object sender, SelectedItemChangedEventArgs e)
        {
            if (e.SelectedItem is Item selectedItem)
            {
                // Clear selection
                ItemsListView.SelectedItem = null;
    
                // TODO: Show a dialog for editing or deleting the selected item
                // For now, we'll just delete the item
                _viewModel.DeleteItem(selectedItem.Id);
            }
        }
    }
    
    
    1 person found this answer helpful.

0 additional answers

Sort by: Most helpful

Your answer

Answers can be marked as Accepted Answers by the question author, which helps users to know the answer solved the author's problem.