簡體   English   中英

如何將一個窗口中的數據網格與另一窗口中的文本框綁定?

[英]How to bind datagrid from one window with textboxes in other window?

我正在嘗試創建一個包含機場數據的主窗口,以及一個用於編輯數據的單獨窗口。 目前,我只能在同一窗口中綁定數據網格和文本框,但是如何在EditWindow中綁定它們呢?

機場窗口(主窗口):

public partial class AirportsWindow : Window
    {

        public AirportsWindow()
        {
            InitializeComponent();
            using (SQLiteConnection dataConnection = new SQLiteConnection()) 
            {
                try
                {
                    dataConnection.ConnectionString = "Data Source=database.db;Version=3;";
                    dataConnection.Open();
                    SQLiteCommand dataCommand = new SQLiteCommand();
                    dataCommand.Connection = dataConnection;


                }
                catch (Exception e)
                {
                    Console.WriteLine("Грешка при повезивању с базом " + e.Message);

                }
            }

            string database_connection = "Data Source=database.db;Version=3;";
            string query = String.Format("SELECT * FROM airports WHERE active = '1'");

            SQLiteConnection connection = new SQLiteConnection(database_connection);
            connection.Open();

            SQLiteCommand command = new SQLiteCommand(query, connection);
            SQLiteDataAdapter dataAdapter = new SQLiteDataAdapter(command);

            DataTable data = new DataTable();           
            dataAdapter.Fill(data);
            dgAirports.DataContext = data;

        }

這是EditWindow:

<Grid x:Name="FormGrid" DataContext="{Binding SelectedItem, ElementName=Dgrid}">

        <Label x:Name="lblAirportId" Content="ИД" HorizontalAlignment="Left" VerticalAlignment="Top" Margin="10,12,0,0"/>
        <TextBox x:Name="txtAirportId" Text="{Binding ElementName=dgAirports, Path=SelectedValue.id}" HorizontalAlignment="Left" Height="23" TextWrapping="Wrap" VerticalAlignment="Top" Width="125" Margin="48,13,0,0"/>

        <Label x:Name="lblAirportName" Content="Назив" HorizontalAlignment="Left"  VerticalAlignment="Top" Margin="0,38,0,0"/>
        <TextBox x:Name="txtAirportName" Text="{Binding ElementName=dgAirports, Path=SelectedValue.airportName}" HorizontalAlignment="Left" Height="23" TextWrapping="Wrap" VerticalAlignment="Top" Width="125" Margin="48,41,0,0"/>

        <Label x:Name="lblAirportCity" Content="Град" HorizontalAlignment="Left"  VerticalAlignment="Top" Margin="2,69,0,0"/>
        <TextBox x:Name="txtAirportCity" Text="{Binding ElementName=dgAirports, Path=SelectedValue.airportCity}" HorizontalAlignment="Left" Height="23" TextWrapping="Wrap" VerticalAlignment="Top" Width="125" Margin="48,72,0,0"/>


        <Button x:Name="btnEdit" Content="Додај" HorizontalAlignment="Left" Margin="10,100,0,0" VerticalAlignment="Top" Width="75" Click="btnEdit_Click"/>
        <Button x:Name="btnCancel" Content="Одустани" HorizontalAlignment="Left" Margin="98,100,0,0" VerticalAlignment="Top" Width="75" Click="btnCancel_Click"/>
    </Grid>
</Window>

這也是我在AirportsWindow(主窗口)中完成並綁定的方式

<Grid>
        <DataGrid x:Name="dgAirports" HorizontalAlignment="Left" Margin="10,10,0,0" VerticalAlignment="Top" Height="100" Width="272" ItemsSource="{Binding}" AutoGenerateColumns="False" CanUserAddRows="false" VerticalScrollBarVisibility="Hidden">
            <DataGrid.Columns>
                <DataGridTextColumn Header="Шифра" Binding="{Binding Path = id}" Width="*"/>
                <DataGridTextColumn Header="Назив" Binding="{Binding Path = airportName}"  Width="*"/>
                <DataGridTextColumn Header="Град" Binding="{Binding Path = airportCity}" Width="*"/>
            </DataGrid.Columns>
        </DataGrid>

        <Label x:Name="lblAirportId" Content="ИД" HorizontalAlignment="Left" Margin="123,115,0,0" VerticalAlignment="Top"/>
        <TextBox x:Name="txtAirportId" Text="{Binding ElementName=dgAirports, Path=SelectedValue.id}" HorizontalAlignment="Left" Height="23" Margin="157,115,0,0" TextWrapping="Wrap" VerticalAlignment="Top" Width="125"/>

        <Label x:Name="lblAirportName" Content="Назив" HorizontalAlignment="Left" Margin="109,142,0,0" VerticalAlignment="Top"/>
        <TextBox x:Name="txtAirportName" Text="{Binding ElementName=dgAirports, Path=SelectedValue.airportName}" HorizontalAlignment="Left" Height="23" Margin="157,143,0,0" TextWrapping="Wrap" VerticalAlignment="Top" Width="125"/>

        <Label x:Name="lblAirportCity" Content="Град" HorizontalAlignment="Left" Margin="115,168,0,0" VerticalAlignment="Top"/>
        <TextBox x:Name="txtAirportCity" Text="{Binding ElementName=dgAirports, Path=SelectedValue.airportCity}" HorizontalAlignment="Left" Height="23" Margin="157,171,0,0" TextWrapping="Wrap" VerticalAlignment="Top" Width="125"/>

        <Button x:Name="btnAdd" Content="Додај" HorizontalAlignment="Left" Margin="10,115,0,0" VerticalAlignment="Top" Width="75" Click="btnAdd_Click"/>
        <Button x:Name="btnEdit" Content="Измени" HorizontalAlignment="Left" Margin="10,142,0,0" VerticalAlignment="Top" Width="75" Click="btnEdit_Click"/>
        <Button x:Name="btnDelete" Content="Избриши" HorizontalAlignment="Left" Margin="10,170,0,0" VerticalAlignment="Top" Width="75" Click="btnDelete_Click"/>
    </Grid>
</Window>

使用在主窗口數據上下文中實現的ICommand或RelayCommand,並將所選項目設置為編輯窗口的數據上下文。 您可以通過編輯窗口構造函數將其作為參數傳遞。

當前實現中的問題是您正在從單獨的xaml中按名稱(Dgrid)訪問元素。

我的建議是嘗試使用MVVM模式實現您的應用程序。

您應該使用MVVM模式,或者至少使用部分想法。

模型:

public class MyModel
{
    public string MyProperties { get; set; }
}

主窗口:

public partial class Window1 : Window
{
    public MyModel Model { get; set; }

    public Window1()
    {
        InitializeComponent();

        // Only time creating an instance of MyModel
        Model = new MyModel();
        Model.MyProperties = string.Empty;

        // Pass reference of MyModel to other Windows (or even better ViewModels)
        Window2 wnd = new Window2(Model);

        wnd.Show();


        MessageBox.Show(Model.MyProperties);
        // Output: "This is an example."
    }
}

子窗口:

public partial class Window2 : Window
{
    // Don't create another instance, just pass the existing instance reference
    public MyModel Model { get; set; }

    public Window2(MyModel model)
    {
        InitializeComponent();

        Model = model;

        // Modifying Properties from here will also update in Window1
        Model.MyProperties = "This is an example.";
    }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM