| 首页 | 新闻 | 网页 | 设计 | 色彩 | 原创 | 视觉 | 素材 | 动漫 | 酷站 | 策划 | 文案 | 访谈 | 运营 | 编程 | 数据库 | 服务器 | 下载 | 图库 | 
您的位置: 幽幽天空 > 网页 > 编程开发 > VB教程 > 文章正文 用户登录
龙太极/100m/asp/
无限网络提供50M 
苏能科技100M/FTP
悠博科技50M/FTP/
华云网络30M/FTP/
RealTracker提供免
用Adsense挣大钱系
XML connector的讨
ASP+FLASH+ACCESS
《Flash ActionSc

用ActiveX控件封装MaskEdit控件-->解决不能绑定的问题           

用ActiveX控件封装MaskEdit控件-->解决不能绑定的问题

作者:佚名 来源:csdn 作者: blstar/ 更新:2006-8-25 21:05:35 错误报告 我要投稿

參考決定或改作通用的activeX控件.

         (1)新建一ActiveX Control工程.
             放置一maskedit控件於上.
             其設置屬性參考如下:
                usercontrol之name:DataDate.
  usercontrol之DataBindingBehavior設定1-VvbSimpleBound
                MaskedtBox之name:mskDate.

          (2).新增一數據屬性用於綁定.操作如下(我用為繁體系統,可能說法不大一樣).
             打開菜單: 增益集-->增益集管理員.
             載入Visual Basic AcitveX控制項介面精靈並啟動.
      運行至:建立自訂的介面成員處新增一Property:DateValue(此屬性即為您要操作綁定的東東).
      下一步確定對應關系:
       將常用的公用項目中的屬性事件按照綁定至mskDate.如mskDate無相關之屬性和可綁定至usercontrol上.
              在公用項目中將DateValue之資料類型設定Date型
              完成上述操作.
 


          (3). 將DateValue設定資料綁定屬性.

               點選usercontrol。
        打開  工具--->程序屬性.
              
               從名稱欄位選擇DateValue.
               將資料連結項中如下選擇打上勾:
               “屬性具資料連結功能”
               “在屬性值改變前,先呼叫CanPropertyChange.
                “即時更新”

                此時DataValue即具有數據綁定功能。此控件的屬性中就會增加諸如DataSource.DataField等東東.

           (4).編寫代碼。
             a.設定控件大小.

  Private Sub UserControl_Resize()
   MskDate.Move 0, 0, UserControl.Width, usercontrol.Height
  End Sub
             b.將dateValue的代碼修正如下:
        Public Property Let DateValue(ByVal New_DateValue As Date)
      m_DateValue = New_DateValue
      PropertyChanged "DateValue"
      If Not IsEmpty(m_DateValue) Then
          If IsDate(m_DateValue) Then
              If Year(m_DateValue) > 1970 Then
                  MskDate.Text = Format(m_DateValue, "yyyy/mm/dd")
              Else
                  MskDate.Text = "____/__/__"
              End If
          Else
              MskDate.Text = "____/__/__"
          End If
      Else
          MskDate.Text = "____/__/__"
      End If
  End Property
,此處即為判斷所傳進來的值是否合乎要求,如果是有效的話就顯示在mskDate中,否則就顯示成其他的方式。

Private Sub MskDate_Validate(Cancel As Boolean)

If IsDate(Trim(MskDate.Text)) Then
    If CanPropertyChange("DateValue") Then
        m_DateValue = CDate(MskDate.Text)
        PropertyChanged "DateValue"
    End If
Else
    MsgBox "Invalid date value!", vbExclamation, "Date Error!"
   
    If Not IsEmpty(m_DateValue) Then
        If IsDate(m_DateValue) Then
            If Year(m_DateValue) > 1970 Then
                MskDate.Text = Format(m_DateValue, "yyyy/mm/dd")
            Else
                MskDate.Text = "____/__/__"
            End If
        Else
            MskDate.Text = "____/__/__"
        End If
    Else
        MskDate.Text = "____/__/__"
    End If
   
End If
End Sub

'此處即判斷mskDate的值是否有效,如果有效的話就調用   PropertyChanged "DateValue" . 資料就會更改DataField所綁定的資料欄位的值 .
 
 最後將工程編譯成控件DataDate.ocx 加以引用,DataValue屬性即相當於text的text屬性在文檔中可以直接調用.
 
          用以上方法可以自定義資料綁定控件用於我們的特殊處理。

                                                            lee_jvn於2001.02.15
        OICQ:37198873           

文章录入:skyuu    责任编辑:skyuu 
  • 上一篇文章:

  • 下一篇文章:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    发表评论:
    姓名:  评 分: 1分 2分 3分 4分 5分
     
  • 严禁发表危害国家安全、政治、黄色淫秽等内容的评论。
  • 用户需对自己在使用幽幽天空服务过程中的行为承担法律责任。
  • 本站管理员有权保留或删除评论内容。
  • 评论内容只代表机友个人观点,与本网站立场无关。