⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 columncollection.cls

📁 防Listview控件源码
💻 CLS
字号:
VERSION 1.0 CLASS
BEGIN
  MultiUse = -1  'True
  Persistable = 0  'NotPersistable
  DataBindingBehavior = 0  'vbNone
  DataSourceBehavior  = 0  'vbNone
  MTSTransactionMode  = 0  'NotAnMTSObject
END
Attribute VB_Name = "ColumnCollection"
Attribute VB_GlobalNameSpace = False
Attribute VB_Creatable = True
Attribute VB_PredeclaredId = False
Attribute VB_Exposed = False
Option Explicit

Private m_clsItems()    As Column
Private m_lngColCount   As Long

Public Property Get Count() As Long
    Count = m_lngColCount
End Property

Public Property Get Item(index) As Column
    Dim i       As Long
    Dim strKey  As String
    
    If IsNumeric(index) Then
        Set Item = m_clsItems(CLng(index))
    Else
        strKey = index
        For i = 0 To m_lngColCount - 1
            If StrComp(m_clsItems(i).key, strKey, vbTextCompare) = 0 Then
                Set Item = m_clsItems(i)
                Exit Property
            End If
        Next
        
        Err.Raise 9
    End If
End Property

Public Sub Remove(index)
    Dim i       As Long
    Dim strKey  As String
    
    If IsNumeric(index) Then
        i = CLng(index)
    Else
        strKey = index
        For i = 0 To m_lngColCount - 1
            If StrComp(m_clsItems(i).key, strKey, vbTextCompare) = 0 Then
                Exit For
            End If
        Next
    End If
    
    If i > m_lngColCount - 1 Then
        Err.Raise 9
    End If

    Set m_clsItems(i) = Nothing
    CopyMemory m_clsItems(i), m_clsItems(i + 1), 4 * (m_lngColCount - (i + 1))
    ZeroMemory m_clsItems(m_lngColCount - 1), 4
    m_lngColCount = m_lngColCount - 1
End Sub

Public Function Add(Optional ByVal key As String = "") As Column
    Dim i       As Long
    
    For i = 0 To m_lngColCount - 1
        If StrComp(m_clsItems(i).key, key, vbTextCompare) = 0 Then
            Err.Raise 300, , "Objekt nicht eindeutig in Aufz鋒lung!"
        End If
    Next
    
    ReDim Preserve m_clsItems(m_lngColCount) As Column
    Set m_clsItems(m_lngColCount) = New Column
    m_clsItems(m_lngColCount).key = key
    Set Add = m_clsItems(m_lngColCount)
    m_lngColCount = m_lngColCount + 1
End Function

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -