如何在表单和页面之间传递变量

问题描述 投票:0回答:1

在我的项目(WPF)中,有一个表单(其中声明了一个对象),其中包含一个框架,该框架根据单击的按钮显示不同的页面。在一个页面中,我拖动一个文件,然后我得到了路径。如何将路径返回到主窗体,以便将其“发送”到对象? (然后表格中的其他功能将使用它)

主要表格的(部分)代码

    CSV csv = new CSV();
    public MainWindow()
    {
        InitializeComponent();
        Main.Content = new LoadCSVPage();
    }
    public MainWindow(string path)
    {
        InitializeComponent();
        csv.SetLocation(path);
    }

LoadCSV代码

public LoadCSVPage()
    {
        InitializeComponent();
    }
    private void LoadCSV_DragEnter(object sender, DragEventArgs e)
    {
        string filePath = "";
        string[] files = (string[])e.Data.GetData(DataFormats.FileDrop);
        foreach (string file in files)
        {
            filePath = file;
        }
        MainWindow main = new MainWindow(filePath);
        main.Show();
    }

我明白了什么是错过的!将变量传递给主构造函数后,我没有显示它(通过main.show)。现在我已插入它,它并不能说服我。有更清洁的方法吗?哦不,有问题。使用main.show创建一个额外的窗口!

c# wpf
1个回答
0
投票

我开始说有很多方法可以达到你想要的效果。我看到的第一个问题(即使您没有发布项目的XAML部分)是您正在显示MainWindow两次:第一个显示它时,第二个是您在页面内拖动文件时。

一个想法可能是将Csv对象传递给页面:

public CSV csv = new CSV();
public MainWindow()
{
    InitializeComponent();
    Main.Content = new LoadCSVPage(csv);
}

public partial class LoadCSVPage: Page
{
    private CSV _csv;

    public LoadCSVPage(CSV mainCsv)
    {
        InitializeComponent();
        _csv = mainCsv;
    }
    private void LoadCSV_DragEnter(object sender, DragEventArgs e)
    {
        string filePath = "";
        string[] files = (string[])e.Data.GetData(DataFormats.FileDrop);
        //foreach (string file in files)
        //{
            //This also is not really clear: what happen if you drag more then one file? 
            //This way you are cycling for each file, but you are selecting the last` 
            //filePath = file;
        //}
       if(files.Length > 0)
       {
           filePath = files.Last();
       }
       // Here the csv object can obtain the filePath
       _csv.SetLocation(filePath);

    }
}

然后,您可以直接从页面方法传递路径。

© www.soinside.com 2019 - 2024. All rights reserved.