如何调用C#类的COM Interop,使用javascript的方法

时间:2013-08-10 10:31:40

标签: c# javascript html com

我创建了一个C#Class的COM Interop来访问这个interop usng javascript。 Class包含一个Addition()方法,但该方法无法在javascript中访问。

代码如下

接口IMathInterface

namespace CCWTEST
{
    [Guid("756892A0-1242-4BF7-984D-C13E68000E8E")]
    [ComVisible(true)]
    [InterfaceType(ComInterfaceType.InterfaceIsIDispatch)]
    public interface IMathInterface
    {
        [DispId(1)]
        int Addition(int i, int j);
    }
}

Class ClassMath

[Guid("CA9AD3A7-BD31-4BE2-A780-8864D493BA5F")]
[ComVisible(true)]
[ClassInterface(ClassInterfaceType.None)]
[ProgId("CCWTEST.ClassMath")]
public class ClassMath : IMathInterface
{
    [ComVisible(true)]
    public int Addition(int x, int y)
    {
        return x + y;
    }
}

然后创建的snk文件CCWMathTest.snk也注册到GACUtil。然后使用RegAsm命令创建一个tlb文件。所有这些都成功完成。

然后创建一个Web应用程序以将类方法访问为javascript。

代码

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs" Inherits="WebApplication1.WebForm1" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <object classid="CLSID:CA9AD3A7-BD31-4BE2-A780-8864D493BA5F" height="0" width="0"
        id="obj7" name="obj7">
    </object>
       <title></title>
    <script type="text/javascript">
        window.onload = onLoad;
        function onLoad() {

            alert(obj7.Addition(3,1));

        }
    </script>
</head>
<body>
    <form id="form1" runat="server">
    <div>
    </div>
    </form>
</body>
</html>

运行此代码时出现错误“对象不支持属性或方法'添加'” 如何使用COM interop

在Javascript中访问此方法

1 个答案:

答案 0 :(得分:0)

你为什么要用javascript调用它?在您的页面上创建一个WebMethod,它调用COM对象,然后从javascript通过AJAX调用此方法。像这样:

//server side
[WebMethod]
public static string DoSomething()
{
    //call COM
    return "something";
}

//client side
$.ajax({
    type: "POST",
    url: "page.aspx/DoSomething",
    contentType: "application/json; charset=utf-8",
    dataType: "json",
    success: OnSuccess,
    failure: function (response) {
        alert(response.d);
        },
        error: function (response) {
            alert(response.d);
        }
});