ScriptControl控件执行自定义VBS脚本示例分析
执行 分析 示例 脚本 自定义 控件 vbs
2023-06-13 09:14:49 时间
ScriptControl控件-msscript.ocxmsscript.oca
"AllowUI:可读写,布尔值,检测是否允许运行用户的接口元素.如果为False,则诸如消息框之类的界面元素不可见.
"CodeObject:返回宿主被调用的特定的公用成员对象.只读.
"Modules:只读.返回宿主提供给脚本的组件库模块.COM组件通常都是以对象收集的形式向用户提供可以留给用户二次开发的对象集合,每一个收集即一个Modules(模块).
"Language:设置或获取脚本引擎解释的语言,例如:VBScript.JScript.
"Name:返回模块.过程.或者对象的名字,只读属性.
"Procedures:返回模块中定义的过程,只读.
"SitehWnd:窗口句柄,如果本控件以ActiveX控件创建,则此属性为控件的容器;如果是以自动化对象创建,则为0,即桌面.此属性可读写.
"State:设置或返回控件的状态,如果为0,控件只执行语句但不转发事件,为1则为加入的本控件接受的对象转发事件.
"Timeout:设置或返回控件的相应脚本的超时值.当超时值到达时,将引发Timeout事件.也可设为-1,表示无超时设定.
"UseSafeSubset:设置或返回宿主程序是否关心安全.宿主程序的安全级别可以从此属性设置.
"Error:错误对象,发生错误时,此属性返回一个错误对象.
"AddCode:往一个模块加入一些代码.格式为:AddCodecode,可以调用多次.
"AddObject:向一个模块加入一个对象,格式:ScriptControl.AddObject(name,object[,addMembers]),name为欲加入的对象名字,Object为实际的对象,addMembers为可选指示此对象是否为全局对象,False为局部对象.只有往本对象中加入对象后才能在脚本中使用
"Eval:求值表达式.格式为object.eval_r(expression).
"ExecuteStatement:解释并执行脚本语句.格式:object.ExecuteStatementstatement.
"Reset:丢弃所有的对象和代码.State属性将为0.
"Run:运行一个指定的过程.格式:object.Run(procedureName,parameters()),procedureName为要运行的过程名,parameters()为参数
"仅有两个事件:error和TimeOut.前者可以用于错误捕获,后者在脚本得不到响应时发生.
PrivateSubCommand1_Click()
DimstrFunAsString
Dima,bAsLong
a=2
b=3
strFun="functionAdd(a,b)"&vbCrLf&"Add=a+b"&vbCrLf&"End Function"&vbCrLf
ScriptControl1.Modules.Add"MyCode"
ScriptControl1.Modules.Item(1).AddCodestrFun
MsgBoxScriptControl1.Run("Add",a,b)
EndSub
PrivateSubCommand2_Click()
DimCodeStrAsString
CodeStr="msgbox2+3"&vbCrLf
ScriptControl1.ExecuteStatementCodeStr
EndSub
PrivateSubCommand3_Click() //运行print运算表达式
DimCodeStrAsString
CodeStr=Text1.Text
CodeStr=Mid(CodeStr,6)
MsgBoxScriptControl1.Eval(CodeStr)
EndSub
相关文章
- 【说站】mysql关键字的执行顺序分析
- Postgresql源码(82)SPI模块拆解分析一:执行简单SQL获取结果
- 关机了 cron job 怎么办,开机后还会再执行吗?
- 分布式sql引擎原理分析-逻辑执行计划生成
- 【OkHttp】OkHttp 源码分析 ( 同步 / 异步 Request 请求执行原理分析 )
- 【Linux 内核】实时调度类 ⑥ ( 实时调度类核心函数源码分析 | 插入进程到执行队列 | 从执行队列中选择优先级最高的进程 )
- 【开发环境】Ubuntu 中使用 VSCode 开发 C/C++ ⑤ ( tasks.json 中的 args 数组配置分析 | 编译并执行 C++ 程序 )
- Gorm-原生 SQL 查询和执行(一)
- MySQL学习之EXPLAIN执行计划详解及最佳实践数据库
- Hive(六)hive执行过程实例分析与hive优化策略详解大数据
- Spark算子执行流程详解之六大数据
- 分析Linux 深入研究:执行日志分析(linux执行日志)
- 快速高效地执行Oracle脚本(oracle脚本执行)
- Maximizing Database Efficiency: The Power of Oracle Indexing Explained(oracle执行索引)
- 掌握Linux命令执行时间的方法和技巧(linux命令执行时间)
- 实现高效查询MySQL一次性执行多条查询(mysql一执行多条查询)
- 时Oracle数据库系统设置最长语句执行时间为5小时(oracle保留5小)
- Oracle中SQL语句查询执行顺序研究(oracle中执行顺序)
- 实现数据库优化Oracle中利用SQL语句实现数据库性能优化(oracle中执行sql)
- 执行InsertExec时的隐藏开销分析
- mysql执行时间为负数的原因分析
- Python解释执行原理分析