亚洲视频二区_亚洲欧洲日本天天堂在线观看_日韩一区二区在线观看_中文字幕不卡一区

公告:魔扣目錄網(wǎng)為廣大站長提供免費收錄網(wǎng)站服務,提交前請做好本站友鏈:【 網(wǎng)站目錄:http://www.430618.com 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

Electron.NET是一個嵌入了ASP.NET Core的Electron的封裝,通過Electron.NET可以構建基于.NET5的跨平臺的桌面應用,使得開發(fā)人員只需要使用ASP.NET Core和 Blazor就可以勝任桌面應用的開發(fā)工作。

開發(fā)環(huán)境

  • 操作系統(tǒng)windows/macOS/linux
  • .NET5.0
  • npm

創(chuàng)建新項目

  • 創(chuàng)建文件夾
mkdir ElectronNETDemon
  • 創(chuàng)建解決方案
dotnet new sln
  • 創(chuàng)建項目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應該出現(xiàn)在你的 ASP.NET Core項目中。
electronize init
  1. 運行以下命令啟動程序
electronize start

第一次啟動期間可能需要等待漫長的時間,如啟動失敗可以設置 npm 的源鏡像

npm install -g cnpm --registry=https://registry.npm.taobao.org
使用.NET5、Blazor和Electron.NET構建跨平臺桌面應用

 

  • 構建桌面應用

輸入以下命令構建各平臺的桌面應用,默認為這些平臺生成 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) 中引入靜態(tài)文件
<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
  • 為了動態(tài)地顯示彈出組件,需要在 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加入以下代碼,觸發(fā)按鈕的點擊事件
@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");
    }
}
使用.NET5、Blazor和Electron.NET構建跨平臺桌面應用

 

本文 GitHub 代碼

https://github.com/huangmingji/ElectronNETDemon

相關文檔

  • ElectronNet
  • Ant Design Blazor
  • ASP.NET Core Blazor

文章來源于學習使我快樂 ,作者黃明基

分享到:
標簽:NET
用戶無頭像

網(wǎng)友整理

注冊時間:

網(wǎng)站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨大挑戰(zhàn)2018-06-03

數(shù)獨一種數(shù)學游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數(shù)有氧達人2018-06-03

記錄運動步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定