• 使用.NET5、Blazor和Electron.NET构建跨平台桌面应用


    Electron.NET是一个嵌入了ASP.NET Core的Electron的封装,通过Electron.NET可以构建基于.NET5的跨平台的桌面应用,使得开发人员只需要使用ASP.NET Core和 Blazor就可以胜任桌面应用的开发工作。

    开发环境

    创建新项目

    • 创建文件夹
    mkdir ElectronNETDemon
    
    • 创建解决方案
    dotnet new sln
    
    • 创建项目ElectronNETDemon
    dotnet new blazorserver -f net5.0 -o ElectronNETDemon
    
    • 将项目“ElectronNETDemon/ElectronNETDemon.csproj”添加到解决方案中。
    dotnet sln ElectronNETDemon.sln add ElectronNETDemon
    
    • 切换到项目目录
    cd ElectronNETDemon
    
    • 将包“ElectronNET.API”的 PackageReference 添加到项目ElectronNETDemon
    dotnet add package ElectronNET.API
    
    • 修改Program.cs使用Electron扩展
    public static IHostBuilder CreateHostBuilder(string[] args) =>
        Host.CreateDefaultBuilder(args)
            .ConfigureWebHostDefaults(webBuilder =>
            {
                webBuilder.UseElectron(args);
                webBuilder.UseStartup<Startup>();
            });
    
    • 修改Startup.cs,打开Electron窗口
    public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
    {
        ...
    
        // Open the Electron-Window here
        Task.Run(async () => await Electron.WindowManager.CreateWindowAsync());
    }
    
    • 删除应用上的 https 相关配置
    1. launchSettings.json
    2. Startup.cs
    app.UseHsts();
    app.UseHttpsRedirection();
    
    • 启动应用程序
    1. 要启动应用程序,请确保已将'ElectronNET.CLI'软件包安装为全局工具:
    dotnet tool install ElectronNET.CLI -g
    
    1. 然后初始化Electron.NET项目,electronnet.manifest.json应该出现在你的 ASP.NET Core项目中。
    electronize init
    
    1. 运行以下命令启动程序
    electronize start
    

    第一次启动期间可能需要等待漫长的时间,如启动失败可以设置 npm 的源镜像

    npm install -g cnpm --registry=https://registry.npm.taobao.org
    

    • 构建桌面应用

    输入以下命令构建各平台的桌面应用,默认为这些平台生成 x64 包。

    electronize build /target win
    electronize build /target osx
    electronize build /target linux
    

    如需构建 X86 的包,请使用以下命令

    electronize build /target custom "win7-x86;win32" /electron-arch ia32 
    

    将包“AntDesign”的 PackageReference 添加到项目ElectronNETDemon

    dotnet add package AntDesign --version 0.1.0-*
    
    • 修改Startup.cs,在项目中注册Antdesign
    public void ConfigureServices(IServiceCollection services)
    {
        services.AddAntDesign();
        
        ...
    }
    
    • 在 wwwroot/index.html(WebAssembly) 或 Pages/_Host.cshtml(Server) 中引入静态文件
    <link href="_content/AntDesign/css/ant-design-blazor.css" rel="stylesheet">
    <script src="_content/AntDesign/js/ant-design-blazor.js"></script>
    
    • 在 _Imports.razor 中加入命名空间
    @using AntDesign
    
    • 为了动态地显示弹出组件,需要在 App.razor 中添加一个 组件。
    <Router AppAssembly="@typeof(Program).Assembly" PreferExactMatches="@true">
        <Found Context="routeData">
            <RouteView RouteData="@routeData" DefaultLayout="@typeof(MainLayout)"/>
        </Found>
        <NotFound>
            <LayoutView Layout="@typeof(MainLayout)">
                <p>Sorry, there's nothing at this address.</p>
            </LayoutView>
        </NotFound>
    </Router>
    
    <AntContainer />
    
    • 最后我们就可以在 razor 页面中使用 AntDesign,在Index.razor加入以下代码,触发按钮的点击事件
    @inject MessageService _message
    @page "/"
    
    <h1>Hello, world!</h1>
    
    Welcome to your new app.
    
    <SurveyPrompt Title="How is Blazor working for you?" />
    
    
    <Button Type="primary" OnClick="Success">Hello World!</Button>
    
    @code {
        private async Task Success()
        {
            await _message.Success("This is a success message");
        }
    }
    

    本文 GitHub 代码

    https://github.com/huangmingji/ElectronNETDemon

    相关文档

    作者:黄明基
    出处:http://www.cnblogs.com/229015504/
    如果你喜欢本文章,欢迎转载,请保留此段声明,且在文章页面明显位置给出原文连接。
    如果文中有什么错误,欢迎指出。以免更多的人被误导。欢迎大家扫描右边二维码关注公众号。
  • 相关阅读:
    关于连通性问题的Tarjan算法暂结
    【BZOJ 3925】[Zjoi2015]地震后的幻想乡 期望概率dp+状态压缩+图论知识+组合数学
    Kruskal算法及其类似原理的应用——【BZOJ 3654】tree&&【BZOJ 3624】[Apio2008]免费道路
    【NOIP模拟赛】Drink 二维链表+模拟
    【BZOJ 2957】楼房重建&&Codechef COT5 Count on a Treap&&【NOIP模拟赛】Weed 线段树的分治维护
    【BZOJ 4198】[Noi2015]荷马史诗 哈夫曼编码
    【NOIP模拟赛】chess 建图+spfa统计方案数
    【TMD模拟赛】上低音号 链表
    【TMD模拟赛】黄金拼图 Cao
    【BZOJ 4007】[JLOI2015]战争调度 DP+搜索+状压
  • 原文地址:https://www.cnblogs.com/huangmingji/p/15584938.html
Copyright © 2020-2023  润新知