我用 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();
}
我在这里错过了什么?
最佳答案
您从错误的方向处理问题。单击按钮时,您不想创建新的加载项,您真正想要的是访问 Excel 启动时 VSTO 为您创建的加载项实例,可通过 访问Globals.ThisAddIn
。
将表单中的代码更改为以下内容:
private void btnUploadTestCases_Click(object sender, EventArgs e)
{
var addIn = Globals.ThisAddIn;
addIn.RefreshExcelData();
}
... 它应该很有魅力。
话虽这么说,这个方法在 ThisAddIn 上有充分的理由吗?一般来说,ThisAddIn 应该用于在 Excel 启动/关闭时连接和拆除加载项,我建议尽可能少地在其中放置逻辑。
关于c# - 如何访问 ThisAddin.cs 文件中的方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12021797/