百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

React框架集成.net示例(react框架的原理)

ccwgpt 2025-03-25 11:30 23 浏览 0 评论

不知小伙伴们有没有遇到过这样的需求,在web前端里需要调用其他语言编写的方法,再具体一点,比如集成一个硬件设备,一般来说,硬件配套的会有一个windows桌面应用的客户端,也就是.net。然后我们的浏览器应用要与这个硬件设备交互,那么可不可以省去客户端,让前端直接调用.net的C#函数呢?
为了应对这种需求,出现了WebAssembly技术。
WebAssembly是一种运行在现代网络浏览器中的新型代码,并且提供新的性能特性和效果。它设计的目的不是为了手写代码而是为诸如 C、C++和Rust等低级源语言提供一个高效的编译目标。
简单来说,将C#等代码编译为.wasm格式的文件,就可以给js调用,当然,还包括各种运行环境,dll链接库等,这些都会被打包在一个“沙箱”里。

React集成

下面我们以一个React项目中集成为例说明一下具体使用。
项目结构如下

我们看下C#代码结构,csproj配置文件里配置如下


    
        net8.0
        browser-wasm
        Library
        true
        main.js
        true
        true
        full
        true
        true
        true
        false
    


    
        
    
    
    
        
            
        
        
        
    


    
        
            
        
        
        
    

里面有这么一些关键点,首先指定main.js为调用入口,相当于js和C#的桥梁,里面会定义具体的可调用函数。然后RemoveVendor和CopyVendor会把编译后的一堆文件放到前端的public文件夹下,这个操作想必大家都能理解了。
下面我们看一下主文件Program.cs

这里简单定义了一个方法MyMethod,加上JSExport注解导出使用。
然后在main.js中将其暴露给前端调用。main.js内容如下

import {dotnet} from './_framework/dotnet.js'


globalThis.window = globalThis;
let dotnetRuntimePromise = undefined;
let exports = undefined;


async function createRuntime() {
    try {
        return dotnet
            .withDiagnosticTracing(false)
            .withModuleConfig({
                locateFile: (path, prefix) => {
                    return '/' + path;
                }
            })
            .create();
    } catch (err) {
        console.error(err);
        throw err;
    }
}


export async function initializeRuntimeExports(){
    if (!dotnetRuntimePromise) {
        dotnetRuntimePromise = createRuntime();
        const { getAssemblyExports, getConfig } = await dotnetRuntimePromise;
        const config = getConfig();
        exports = await getAssemblyExports(config.mainAssemblyName)
    }
}


// C#方法
export async function nativeMyMethod(param) {
    return exports.Demo.Demo.MyMethod(param);
}

其中nativeMyMethod就可以给前端js调用了。
我们简单看一下如何调用

const demo = await import('./vendor/main.js')
await demo.initializeRuntimeExports();


const result = await demo.nativeMyMethod("xiaowai");

类似这样调用即可。
dotnet编译命令如下

dotnet publish -c Release

最后我们看一下编译后放在public里面的是哪些东西吧

除了main.js外,在_framework文件夹下是各种编译出来的wasm文件等,包括依赖的各种System动态链接库等,这里还是dll文件格式,如果把csproj中WasmEnableWebcil这个配置改成true就会是wasm格式啦,具体区别大家可以自行了解一下。

最后

WebAssembly技术的成熟度其实并没有很高,文档资料也比较混乱,涉及一些高深的用法歪哥也无法搞清楚,欢迎一起交流指正。

相关推荐

NestJS入门教程系列一

介绍Nest(NestJS)是用于构建高效,可扩展的Node.js服务器端应用程序的框架。它使用渐进式JavaScript,内置并完全支持TypeScript(但开发人员仍然能够使用JavaScrip...

【推荐】一个网盘资源搜索与转存工具,支持移动端与PC端!

如果您对源码&技术感兴趣,请点赞+收藏+转发+关注,大家的支持是我分享最大的动力!!!项目介绍CloudSaver是一个基于Vue3和Express的网盘资源搜索与转存开源实用工具。它支持...

Appium原理精讲

目前使用Appium新版本和旧版本的企业数目都很多,而两个版本的安装过程和api的使用又有较大的区别。但是无论表面上的东东如何变化,内部原理都是一样的。在这里我给大家介绍一下appium的核心,增进大...

Kubernetes最小部署单元Pod

一、Kubernetes与Pod简介在当今云计算和容器化技术盛行的时代,Kubernetes已然成为容器编排领域的中流砥柱。它是一个开源的容器编排平台,由Google基于其内部使用的Bo...

最常用的四种跨域解决方案

前置知识什么是跨域?浏览器发送的请求地址(URL)与所在页面的地址不同(端口/协议/域名其一不同)。简言之,浏览器发出的请求url,与其所在页面的url不一样。此时,同源策略会让浏览器拒收服务器...

Bolt.New —— 全栈AI Web自动编程

Bolt.New是由StackBlitz公司推出的,全栈AI工具,代码编辑、运行、部署,通通一站式搞定。它使用WebContainers技术,无需任何本地安装或配置,在浏览器中,就可以运行完整的No...

Nodejs Express新手教程&高手进阶

NodejsExpress新手教程&高手进阶Express是一个NodeJS平台的框架,主要用于构于Web服务器项目。本文将通过示例介绍适合新手入门的Express基础使用,以及高手进阶知识,如:c...

Express.js 创建Node.js Web应用

Express.js是一个基于Node.js的Web应用框架,框架的设计目的是构建应用的架构和简化应用的开发。框架会解决一些通用的问题,在Express.js中,Express框架会处理如:中间件、代...

JavaScript 的 Express.js 功能及应用场景详解

Express.js是一个基于Node.js的轻量级Web应用框架,主要用于快速构建服务器端应用和API。它的核心功能包括以下关键点:1.路由管理URL路径与HTTP方法映射:通过...

nodejs的express4文件下载

在nodejs的express框架中,下载变得非常简单,就一个方法,res.download()首先express命令行生成项目基本框架:不会的看这里:http://blog.csdn.net/zz...

Express 系列:快速生成一个项目

系列预告本系列将以一个项目入手结合相关技术细节来带领大家一起学习Express这个基于Node.js的后端框架。本文首先将介绍:如何快速的生成一个具有一定结构的Express项目。Express项目结...

nodejs的express自动生成项目框架

nodejs版本为:4.X,express版本为4.X1.全局安装2个模块express、express-generator在命令行输入:npminstall-gexpressnpminsta...

express开发(一)简介与搭建

上周末去了趟上海书城,不愧是上海数得上号的书城,流行的科技书应有尽有,话不多说直接上图。最经典的C语言O(∩_∩)O最流行的java(づ ̄3 ̄)づ超酷的R语言/(ㄒoㄒ)/~~然而,身为一个坚定的前...

Vue+Echarts可视化大屏系统后端框架搭建(附代码)

各位同学,大家好。上节课,前面我们讲解了Vue+Echarts前端部分的设计方法。这节课程,我们开始讲解使用Express进行后端设计的方法。01项目相关理论介绍什么是expressExpress是...

Shopify电商API接口开发

Shopify电商API接口开发上线流程主要包括以下步骤。北京木奇移动技术有限公司,专业的软件外包开发公司,欢迎洽谈合作。前期准备-注册Shopify账号:在Shopify官网注册,用于后续开发测试...

取消回复欢迎 发表评论: