页面通过JS 调用WinForm 组件

由于工作需要,最近开发了个页面通过JS 调用Winform的程序。

 

注意以下几点:

第一,在Winform 组件 中,需要在Js中调用 的中窗体对象,需要加如下标签:

    [Guid("53CDE3DE-1005-43B8-87C5-F1899BF0AC54")]----此GUID可以自己生成一个。
    [System.Runtime.InteropServices.ComVisible(true)]

    public partial class FlowWrapper {...}

    在 我用到的FlowWrapper 类中,有一些public 方法,用来通过JS传入参数,如:

         /// <summary>
        /// 设置数据
        /// </summary>
        /// <param name="key">键</param>
        /// <param name="value">值</param>
        public void SetData(string key, string value)

 

第二,把开发好的Winform 组件打包成安装包。放在Web程序中,提供给用户下载安装。(其实就是把相关的动态库复制到用户机子上,还有就是在注册表中注册)

 

 

第三,在我的页面中,通过如下代码进行调用组件:

<body  >
    <object   id="FlowOcx" classid="clsid:53CDE3DE-1005-43B8-87C5-F1899BF0AC54" width="80%"
        height="80%"  viewastext>
    </object>
 <script type="text/javascript">
        function startOcx()
        {
            try
            {
                var id = "<%=FlowID%>";
                var type= "<%=ActionType%>";
                var ocx = document.getElementById('FlowOcx');
                ocx.SetData("Key_InnerControl", "InnerControl_FlowDefine");
                ocx.SetData("Key_ActionType", type);     --传入参数
                ocx.SetData("Key_FlowID", id);      ---传入参数
                ocx.SetData("Key_StartControl", "");
            }
            catch (ex)
            {
                alert(ex.description);
                alert("流程组件没有安装,需要下载安装!");
                window.location.href = "../../Tools/FlowOcxSetup.msi";
            }
        }
        startOcx();
         
    </script>

 

 

其实也很简单的,但,这个现在只能 在IE下能成功,在Firefox下,调用不成功。不知为何 。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

春哥撩编程

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值