다음을 통해 공유


ApplicationFactory.HasVstoObject 메서드 (_Workbook)

지정된 Excel 통합 문서 개체에 대해 Microsoft.Office.Tools.Excel.Workbook 호스트 항목이 존재하는지 여부를 나타내는 값을 반환합니다.

네임스페이스:  Microsoft.Office.Tools.Excel
어셈블리:   Microsoft.Office.Tools.Excel(Microsoft.Office.Tools.Excel.dll)
  Microsoft.Office.Tools.Excel.v4.0.Utilities(Microsoft.Office.Tools.Excel.v4.0.Utilities.dll)

구문

‘선언
Function HasVstoObject ( _
    workbook As _Workbook _
) As Boolean
bool HasVstoObject(
    _Workbook workbook
)

매개 변수

반환 값

형식: System.Boolean
지정된 Microsoft.Office.Interop.Excel.Workbook 개체에 대해 Microsoft.Office.Tools.Excel.Workbook 호스트 항목이 존재하면 true이고, 그렇지 않으면 false입니다.

설명

응용 프로그램 수준 추가 기능에서 이 메서드를 호출하여 Excel 통합 문서를 닫거나 저장하기 전에 유지하려는 관리되는 컨트롤의 존재 여부를 테스트할 수 있습니다.

[!참고]

workbook 매개 변수는 Microsoft.Office.Interop.Excel._Workbook 형식인데 이 형식은 Microsoft.Office.Interop.Excel.Workbook의 부모 인터페이스입니다.따라서 이 메서드는 두 유형의 개체를 받아들일 수: 및 Microsoft.Office.Interop.Excel._WorkbookMicrosoft.Office.Interop.Excel.Workbook.대개 Excel 통합 문서를 참조할 때는 Microsoft.Office.Interop.Excel.Workbook을 사용합니다.

예제

다음 코드 예제에서는 현재 통합 문서에 연결된 호스트 항목이 있는지 여부를 확인합니다.이 코드를 사용 하려면 실행 된 ThisAddIn 클래스는 Excel 추가 기능에서 프로젝트를 대상으로 .NET Framework 4 또는 .NET Framework 4.5.

Private Sub Application_WorkbookBeforeSave( _
    ByVal Wb As Microsoft.Office.Interop.Excel.Workbook, _
    ByVal SaveAsUI As Boolean, _
    ByRef Cancel As Boolean) Handles Application.WorkbookBeforeSave

    If Globals.Factory.HasVstoObject(Wb) = True Then
        For Each interopSheet As Excel.Worksheet In Wb.Worksheets
            If Globals.Factory.HasVstoObject(interopSheet) = True Then
                Dim vstoSheet As Worksheet = Globals.Factory.GetVstoObject(interopSheet)
                If vstoSheet.Controls.Count > 0 Then
                    System.Windows.Forms.MessageBox.Show( _
                        "The VSTO controls are not persisted when you" _
                        + " save and close this workbook.", _
                        "Controls Persistence", _
                        System.Windows.Forms.MessageBoxButtons.OK, _
                        System.Windows.Forms.MessageBoxIcon.Warning)
                    Exit For
                End If
            End If
        Next
    End If
End Sub
void Application_WorkbookBeforeSave(
    Microsoft.Office.Interop.Excel.Workbook Wb, bool SaveAsUI, 
    ref bool Cancel)
{            
    if (Globals.Factory.HasVstoObject(Wb) == true)
    {                
        foreach (Excel.Worksheet interopSheet in Wb.Worksheets)
        {
            if (Globals.Factory.HasVstoObject(interopSheet) ==  true)
            {
                Worksheet vstoSheet = Globals.Factory.GetVstoObject(interopSheet);
                if (vstoSheet.Controls.Count > 0)
                {
                    System.Windows.Forms.MessageBox.Show(
                        "The VSTO controls are not persisted when you"
                        + " save and close this workbook.",
                        "Controls Persistence",
                        System.Windows.Forms.MessageBoxButtons.OK,
                        System.Windows.Forms.MessageBoxIcon.Warning);
                    break;
                }
            }
        }
    }
}

.NET Framework 보안

  • 직접 실행 호출자의 경우 완전히 신뢰합니다. 이 멤버는 부분적으로 신뢰할 수 있는 코드에서 사용할 수 없습니다. 자세한 내용은 부분 신뢰 코드에서 라이브러리 사용을 참조하십시오.

참고 항목

참조

ApplicationFactory 인터페이스

HasVstoObject 오버로드

Microsoft.Office.Tools.Excel 네임스페이스