5

我在 C# 中创建了一个 Excel 插件项目。现在解决方案包含一个文件ThisAddin.cs,它有一个类ThisAddin。后来我在同一个解决方案中添加了一个名为 Form 的项目。在表单中,当我单击一个按钮时,对于该按钮单击事件,我想在 ThisAddin.cs 文件中调用一个方法。

namespace ExcelAddIn
{
    public partial class ThisAddIn
    {
        public void RefreshExcelData()
        {
        }
    }
}

现在在 MyForm.cs 中,尝试为 ThisAddin 类创建对象时出现编译错误,即 Thisaddin 类没有采用 0 个参数的构造函数。

private void btnUploadTestCases_Click(object sender, EventArgs e)
{
    ThisAddIn objrefresh = new ThisAddin();
}

我在这里想念什么?

4

2 回答 2

14

你是从错误的方向来解决问题的。当您单击按钮时,您不想创建新的加载项,您真正想要的是访问 Excel 启动时由 VSTO 为您创建的加载项实例,可以通过Globals.ThisAddIn.

将表单中的代码更改为以下内容:

private void btnUploadTestCases_Click(object sender, EventArgs e)
{
    var addIn = Globals.ThisAddIn;
    addIn.RefreshExcelData();           
}

...而且它应该具有魅力。

话虽如此,是否有充分的理由让这个方法出现在 ThisAddIn 上?一般来说,ThisAddIn 应该用于在 Excel 启动/关闭时连接和拆除加载项,我建议在其中放置尽可能少的逻辑。

于 2012-08-19T23:29:34.623 回答
3

使用此代码:

Globals.ThisAddIn.Application.StatusBar = "Referesh clicked!!!."; Globals.ThisAddIn.RefreshExcelData();

只要确保您的功能仍然存在public

于 2012-09-12T13:57:10.670 回答