This repo has the experimental .NET MAUI HybridWebView control, which enables hosting arbitrary HTML/JS/CSS content in a WebView and enables communication between the code in the WebView (JavaScript) and the code that hosts the WebView (C#/.NET). For example, if you have an existing React JS application, you could host it in a cross-platform .NET MAUI native application, and build the back-end of the application using C# and .NET.
Example usage of the control:
<hwv:HybridWebView
HybridAssetRoot="hybrid_root"
MainFile="hybrid_app.html"
RawMessageReceived="OnHybridWebViewRawMessageReceived" />
And here's how .NET code can call a JavaScript method:
var sum = await myHybridWebView.InvokeJsMethodAsync<int>("JsAddNumbers", 123, 456);
And the reverse, JavaScript code calling a .NET method:
HybridWebView.SendInvokeMessageToDotNet("CallMeFromScript", ["msg from js", 987]);
In addition to method invocation, sending "raw" messages is also supported.
Projects in this repo:
- HybridWebView --> a cross-platform .NET MAUI control that can load static web assets (HTML, JS, CSS, etc.) and send messages between JavaScript and .NET
- MauiCSharpInteropWebView --> a sample app that shows the basic functionality of sending messages and calling methods between JavaScript and .NET
- MauiReactJSHybridApp --> a sample app that incorporates a pre-existing React-based todo application into a .NET MAUI cross-platform application
See the main discussion topic here: dotnet/maui#12009
Or please log an issue in this repo for any other topics.
To run this app you need to have Visual Studio for Windows or Mac, including the .NET MAUI workload. Then clone this repo, open the solution, and run one of the sample projects.
The MauiReactJSHybridApp sample contains portions of a pre-existing Todo App built using React JS.
The original React JS Todo app sample used here is based on this sample: https://github.com/mdn/todo-react. I created a fork at https://github.com/Eilon/todo-react that incorporates some small changes to call the .NET API from JavaScript to synchronize the Todo list between the two parts of the app.
To make changes to the fork and update the .NET MAUI app, here's what I do:
- Clone of the forked repo and open a terminal/console window in that folder
- Run
yarn
to ensure the JavaScript dependencies are installed - Run
set PUBLIC_URL=/
to establish the root of the app as/
because that's the root of the .NET MAUI HybridWebView app - Run
npm run build
to compile the app and produce a static version of it- If you get this error:
Error: error:0308010C:digital envelope routines::unsupported
- Then run
set NODE_OPTIONS=--openssl-legacy-provider
- And run this again:
npm run build
- If you get this error:
- This will build the HTML/JS/CSS output into a new
./build
folder - Go to the
MauiReactJSHybridApp
'sResources/Raw/ReactTodoApp
folder and delete all the existing files, and replace with the files from the previous step's./build
folder - Then run the MauiReactJSHybridApp from Visual Studio
This project is licensed under the MIT License. However, portions of the incorporated source code may be subject to other licenses:
- The
MauiReactJSHybridApp/Resources/Raw/ReactTodoApp
folder is the output of a build from https://github.com/Eilon/todo-react, which is a modified fork of https://github.com/mdn/todo-react, which is licensed under the Mozilla Public License 2.0.