electron調用c#動態庫


electron調用c#動態庫

新建C#動態庫

  • 方法要以異步任務的方式,可以直接包裝,也可以寫成天然異步

  • 代碼如下

    public class Class1
        {
            public async Task<Object> Invoke(object input)
            {
                return Helper.SayHi("Invoke1:" + (string)input);
            }
    
            public async Task<Object> Invoke2(object input)
            {
                return  Helper.SayHi("Invoke2:" + (string)input);
            }
    
            static class Helper
            {
                public static string SayHi(string param)
                {
                    return ".NET Welcomes " + param;
                }
            }
    

安裝electron-edge-js模塊

  • 調用代碼如下

    
    const edge = require('electron-edge-js');
    console.info("call c#")
    
    var DemoDll = edge.func({
        assemblyFile: "electronedge.dll",
        typeName: "electronedge.Class1",
        methodName: "Invoke"
    });
    var DemoDll2 = edge.func({
        assemblyFile: "electronedge.dll",
        typeName: "electronedge.Class1",
        methodName: "Invoke2"
    });
    // module.exports.DemoDll = DemoDll;
    module.exports.DemoDll = {
        demo: DemoDll,
        demo2:DemoDll2
    };
    
    
    
  • node引用如下

    const DemoDll = require("./csharputil.js");
    
    DemoDll.DemoDll.demo("test", (err, value)=> {
      log.debug(value);
    
    });
    
  • 頁面js引用如下

    • 包裝如下

      function init() {
          const DemoDll = require("F:/yanghuaihua/electronedge/csharputil.js");
      
      
          return {
              demo: DemoDll.DemoDll.demo,
              demo2:DemoDll.DemoDll.demo2
             
          };
      }
      const initRequire = init();
      
    • 引用如下

      
          <script>window.$ = window.jQuery = require('./js/jquery-3.4.1.min.js');</script>
          <script type="text/javascript" src="./js/init.js"></script>
          <script type="text/javascript" src="./js/index.js"></script>
          <script type="text/javascript">
              $("#btn").click(function () {
                  initRequire.demo("test", (err, value) => {
                      $("#demo").append(value);
                      $("#demo").text(value);
                  });
                  setInterval(()=>{
                      initRequire.demo2("test", (err, value) => {
                      $("#demo").append(value);
                      $("#demo").text(value);
                  });
                  }, 1500);
                 
              });
      
          </script>
      

源碼地址

https://github.com/Ants-double/yumi/tree/master/electronedge


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM