C#利用ScriptControl动态执行JS和VBS脚本
本文导语: ScriptControl接口 属性名称 类型 备注 AllowUI BOOL 检测是否允许运行用户的接口元素。如果为False,则诸如消息框之类的界面元素不可见。 CodeObject Object 脚本暴露给宿主调用的对象。只读。 Modules Modules 宿主提供给脚...
属性名称
类型
备注
AllowUI
BOOL
检测是否允许运行用户的接口元素。如果为False,则诸如消息框之类的界面元素不可见。
CodeObject
Object
脚本暴露给宿主调用的对象。只读。
Modules
Modules
宿主提供给脚本的组件库模块。只读。(COM组件通常都是以对象收集的形式向用户提供可以留给用户二次开发的对象集合,每一个收集即一个Modules)
Language
String
设置或获取脚本引擎解释的语言,例如:VBScript、JScript。
Name
String
脚本引擎的名称。只读。
Procedures
Procedures
返回模块中定义的过程的集合
SitehWnd
HWND
在脚本中显示UI的父窗口句柄
State
Enum
设置或返回控件的状态,如果为0,控件只执行语句但不转发事件,为1则为加入的本控件接受的对象转发事件。
Timeout
Long
控件的执行脚本的超时值,-1表示不超时
UseSafeSubset
BOOL
设置或返回宿主程序是否关心安全。宿主程序的安全级别可以从此属性设置
Error
Error
错误对象,发生错误时,此属性返回一个错误对象
方法名称
参数
功能
AddCode
Code As String
往脚本引擎中加入要执行的脚本
AddObject
Name As String, Object As Object, [AddMembers As Boolean = False]
往脚本引擎加入一个对象,以便在脚本中可以使用该对象提供的方法等。
Eval
Expression As String
表达式求值
ExecuteStatement
Statement As String
解释并执行脚本语句
Reset
丢弃所有的对象和代码,将State属性置0。
Run
ProcedureName As String, ParamArray Parameters() As Variant
运行一个指定的过程
事件名称
功能
Error
有错误发生时激发该事件
TimeOut
执行过程超时时发生
/* 添加COM引用:
Library MSScriptControl
C:WINDOWSsystem32msscript.ocx
Microsoft Script Control 1.0
*/
例子:
using MSScriptControl;
namespace zz
{
///
/// scriptengine类
///
public class ScriptEngine
{
private ScriptControl msc;
///
/// 构造函数
///
/// 脚本类型,VBscriptJavaScript
public ScriptEngine(string language)
{
msc = new ScriptControlClass();
msc.UseSafeSubset = true;
msc.Language = language;
((DScriptControlSource_Event)msc).Error += new DScriptControlSource_ErrorEventHandler(ScriptEngine_Error);
((DScriptControlSource_Event)msc).Timeout += new DScriptControlSource_TimeoutEventHandler(ScriptEngine_Timeout);
}
///
/// 运行eval方法
///
/// 表达式
/// 返回值object
public object eval(string expression)
{
return msc.Eval(expression);
}
///
/// 运行run方法
///
/// 入口函数名称
/// 参数
/// 返回值object
public object Run(string mainFunctionName, object[] parameters)
{
return msc.Run(mainFunctionName, ref parameters);
}
///
/// 加入要执行的脚本
///
///
public void AddCode(string Code)
{
msc.AddCode(Code);
}
///
/// 解析并运行
///
/// 代码
public void ExecuteStatement(string Code)
{
msc.ExecuteStatement(Code);
}
///
/// 放弃所有已经添加到 scriptcontrol 中的 script 代码和对象
///
public void Reset()
{
msc.Reset();
}
///
/// 获取或设置脚本语言
///
public string Language
{
get { return msc.Language; }
set { msc.Language = value; }
}
///
/// 获取或设置脚本执行时间,单位为毫秒
///
public int Timeout
{
get { return ((IScriptControl)msc).Timeout; }
set { ((IScriptControl)msc).Timeout = value; }
}
///
/// 设置是否显示用户界面元素
///
public bool AllowUI
{
get { return msc.AllowUI; }
set { msc.AllowUI = value; }
}
///
/// 宿主应用程序是否有保密性要求
///
public bool UseSafeSubset
{
get { return msc.UseSafeSubset; }
set { msc.UseSafeSubset = true; }
}
private void ScriptEngine_Error()
{
//错误事件
}
private void ScriptEngine_Timeout()
{
//超时事件
}
}
}