微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何应对VB中对象库注册失败MSCOMCTL.OCX

今天在打开自己所敲得学生管理系统时,突然之间出现了对象库注册失败,原本上午还可以用,但是下午怎么就打不开了,为什么突然会这样我也不知道原因,但是解决的办法找到了几个,不知道在用VB的其他人是否也遇到了这样的问题

下面就分享一下我的解决办法:

这是我打开学生管理系统时弹出的对话框



接着在我的学生管理系统主界面发现其中一个控件没有正常加载,因此才会出现对象库未注册,

接着我打开VB-----工程----部件 选择相应的控件进行加载,但却已经无法加载.我需要加载的控件如下图:




对此我尝试了四种办法:


①:在VB环境中直接注册


在VB6集成开发环境中,选择“工程/部件”菜单,弹出“部件”对话框。在“控件”页中包含有系统中所有已注册控件的列表,为了注册MSCOMCTL.OCX,可点击列表框旁边的“浏览”按钮,并在“添加ActiveX控件”对话框中选中MSCOMCTL.OCX文件,按“确定”即可。这种方法的优点是注册完的控件可以直接加入到当前的工程中试用。但是有些拥有版权的控件不能用该方法直接注册。(我试过了但是没有成功,只要我一确定VB就无响应了)


:利用REGSVR32工具注册


利用WIN +R 打开运行窗口,在其中输入:regsvr32MSCOMCTL.OCX

按确定进行注册 其图如下:



如果可以成功注册他就会弹出注册成功的对话框,这样我们就注册成功了,打开VB就不会出现错误了,但是如果出现下面的问题:



我就是遇到了这个问题,一般我会进入电脑的安全模式进行注册,而且会成功,重新启动你的电脑按F8进入安全模式。(其实有的时候电脑的一些问题,打开安全模式修复修复,真的很管用,比如说我的电脑有两个漏洞总是没办法修复,进入安全模式修复后在启动就好了(*^__^*) 嘻嘻……)

这是我在安全模式下注册MSCOMCTL.OCX后的图:



用了这种方法再次打开VB后,我们需要注册的控件就可以使用了。


③:以管理员 身份运行命令提示符进行注册


开始----附件------命令提示 管理员的身份运行,

在其中输入:regsvr32MSCOMCTL.OCX 按回车键进行注册,这样的方法也会成功,


看到注册成功的对话框应该很兴奋吧。

其实上面的三种情况我自己都亲自试过了,写下来分享一下,另外还可以通过注册表那里进行注册 希望我的这几个方法会帮到您 (*^__^*) 嘻嘻……

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Format[$] ( expr [ , fmt ] ) format 返回变体型 format$ 强制返回为文本 -------------------------------- 数字类型的格式化 --------------------------------     固定格式参数:     General Number 普通数字,如可以用来去掉千位分隔号     format$("100,1
VB6或者ASP 格式化时间为 MM/dd/yyyy 格式,竟然没有好的办法, Format 或者FormatDateTime 竟然结果和系统设置的区域语言的日期和时间格式相关。意思是尽管你用诸如 Format(Now, "MM/dd/yyyy"),如果系统的设置格式区域语言的日期和时间格式分隔符是"-",那他还会显示为 MM-dd-yyyy     只有拼凑: <%response.write
在项目中添加如下代码:新建窗口来显示异常信息。 Namespace My ‘全局错误处理,新的解决方案直接添加本ApplicationEvents.vb 到工程即可 ‘添加后还需要一个From用来显示错误。如果到这步还不会则需要先打好基础啦 ‘======================================================== ‘以下事件
转了这一篇文章,原来一直想用C#做k3的插件开发,vb没有C#用的爽呀,这篇文章写与2011年,看来我以前没有认真去找这个方法呀。 https://blog.csdn.net/chzjxgd/article/details/6176325 金蝶K3 BOS的插件官方是用VB6编写的,如果  能用.Net下的语言工具开发BOS插件是一件很愉快的事情,其中缘由不言而喻,而本文则是个人首创,实现在了用V
Sub 分列() ‘以空格为分隔符,连续空格只算1个。对所选中的单元格进行处理 Dim m As Range, tmpStr As String, s As String Dim x As Integer, y As Integer, subStr As String If MsgBox("确定要分列处理吗?请确定分列的数据会覆盖它后面的单元格!", _
  窗体代码 1 Private Sub Text1_OLEDragDrop(Data As DataObject, Effect As Long, Button As Integer, Shift As Integer, X As Single, Y As Single) 2 Dim path As String, hash As String 3 For Each fil
  Imports MySql.Data.MySqlClient Public Class Form1 ‘ GLOBAL DECLARATIONS Dim conString As String = "Server=localhost;Database=net2;Uid=root;Pwd=123456;" Dim con As New MySqlConnection
‘導入命名空間 Imports ADODB Imports Microsoft.Office.Interop   Private Sub A1() Dim Sql As String Dim Cnn As New ADODB.Connection Dim Rs As New ADODB.Recordset Dim S As String   S = "Provider=OraOLEDB.Oracl
Imports System.IO Imports System.Threading Imports System.Diagnostics Public Class Form1 Dim A(254) As String    Function ping(ByVal IP As Integer) As String Dim IPAddress As String IPAddress = "10.0.
VB运行EXE程序,并等待其运行结束 参考:https://blog.csdn.net/useway/article/details/5494084 Private Declare Function WaitForSingleObject Lib "kernel32" (ByVal hHandle As Long, ByVal dwMilliseconds As Long) As Long Pr