c# - wpf-单击按钮时动态创建新文本框和文本 block 并将其添加到网格行

标签 c# wpf xaml mvvm textbox

我有一个网格布局。每行有三列。第一列包含一个文本框,第二列和第三列包含文本 block 。

我添加了一个新按钮,我想要做的是,每当用户单击该按钮时,它都会生成一个新行,该行在第 1 列包含一个 TextBox,第 2 和第 3 列包含 TextBlock。

我正在做这个 ss 我想获取用户在每个文本框上输入的值(名称),然后做一些 Web调用服务以检索相关值在同一行的两个 TextBlocks 上显示

我已经搜索了几个与此相关的 stackoverflow 线程,但主要建议您通过将新控件(例如文本框)作为子控件添加到网格布局而不是使用 MVVM 来实现事件处理程序 buttonClicked()。

我想知道是否有任何方法可以使用 MVVM 实现此目的?有什么建议吗?

最佳答案

在仔细阅读上面的评论后,@benPearce 指出了对同一问题的出色回答 dynamically add controls .希望下面的一些额外信息仍然会有所帮助。

要动态添加控件,请使用 ItemsControl 或派生对象并绑定(bind)到您要使用的 View 模型的集合。这只是一个真实的基本示例,为简洁起见省略了一些样板:

XAML

<Window x:Class="MyWpfApp.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:WpfApplication1"
        mc:Ignorable="d"
        Title="MainWindow" Height="350" Width="525">
    <Grid>
        <Grid.RowDefinitions>
            <RowDefinition/>
            <RowDefinition Height="3*"/>
        </Grid.RowDefinitions>
        <Button Content="Add New Entry" Command="{Binding AddNewEntryCommand}"/>
        <ItemsControl Grid.Row="1" ItemsSource="{Binding TextEntryItems}">
            <ItemsControl.ItemTemplate>
                <DataTemplate>
                    <StackPanel Orientation="Horizontal">
                        <TextBlock Text="{Binding Label}"/>
                        <TextBox Text="{Binding Data}"/>
                    </StackPanel>
                </DataTemplate>
            </ItemsControl.ItemTemplate>
        </ItemsControl>
    </Grid>
</Window>

C#

namespace MyWpfApp {
    public class MainWindowViewModel : INotifyPropertyChanged {

        private void AddNewEntry() {
            TextEntryItems.Add(new TextEntryViewModel("NewItem"));
        }

        private ObservableCollection<TextEntryViewModel> textEntryItems;
        public ObservableCollection<TextEntryViewModel> TextEntryItems { get { return textEntryItems; } set { textEntryItems = value; FirePropertyChanged(); } }

        public ICommand AddNewEntryCommand { get { new RelayCommand(AddNewEntry)} }
    }

    public class TextEntryViewModel : INotifyPropertyChanged {

        public TextEntryViewModel(string label) {
            Label = label;
        }

        private string label;
        public string Label { get { return label; } set { label = value; FirePropertyChanged(); } }

        private string data;
        public string Data { get { return data; } set { data = value; FirePropertyChanged(); } }        
    }

}

关于c# - wpf-单击按钮时动态创建新文本框和文本 block 并将其添加到网格行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42102879/

相关文章:

C# 及时查找所有缺失的段

c# - 如何在 C# 中进行比较

c# - 将 byte[] 从 Android 应用程序传递到 C# 控制台应用程序?

c# - 当依赖属性具有 RelativeSource 绑定(bind)时,GetTemplateChild 返回 null

c# - 项目不会出现在 C# 中的 ListBox 中,但在 XAML 中会出现

c# - 在按钮上打开一个新窗口单击 WPF MVVM

c# - 为什么 C# 类可以隐式和显式地从一个接口(interface)继承?

c# - 退出后保留程序的数据

wpf - 两个自定义依赖对象之间的绑定(bind)

c# - Metro-Style App 中的简单径向渐变背景