Electron是由Github上的一支团队和一群活跃贡献者维护。用HTML,CSS和JavaScript来构建跨平台桌面应用程序的一个开源库。 Electron经过将Chromium和Node.Js合并到同一个运行时环境中,并将其打包为Mac,Windows和Linux系统下的应用来实现这一目的。官方地址:https://electronjs.org。Chromium是谷歌浏览器的引擎,Node.js,就是.......还用我说吗?css
Electron.Net是对这项技术的C#实现,棒棒的。( .NET Core版本)html
也是两个月没更了,有灰,某些Bug在修复中,刚入门的时候特纠结,如今整理出来了,让老铁门少些烦恼。node
a、Electron.NET是基于Electron和Node.js的,所以在你开撸以前须要作点准备工做。css3
b、安装Node.js 去https://nodejs.org/en/下载git
c、打开node.js命令行注册一个配置文件,敲命令:npm config set registry xxx (xxx随便写, 你就写xxx也行, 野路子, 但没毛病)github
d、上面那个命令运行完会生成一个.npmrc文件。找到它(c:\User\Administrator\.npmrc),我找不到就用everything搜索。npm
e、编辑你找到的文件,换一些源,阿里的快,清空全部内容并写入:json
registry=https://registry.npm.taobao.org
sass_binary_site=https://npm.taobao.org/mirrors/node-sass/
phantomjs_cdnurl=http://npm.taobao.org/mirrors/phantomjs
ELECTRON_MIRROR=http://npm.taobao.org/mirrors/electron/api
f、继续敲命令 npm install -g electron 浏览器
g、继续敲命令npm install electron-packager --global
h、分别敲node -v和electron -v,看看装没装上
i、如图:
j、不是很懂Node.js的配置,除了这个环境须要,其它我也不用它。
a、打开你的vs,下载ElectronNET.API
这个包包。
b、Program.cs里加上.UseElectron(args)。
WebHost.CreateDefaultBuilder(args) .UseStartup<Startup>() .UseElectron(args) .Build();
c、在Startup.cs里,Configure方法中,在app.UseMvc()下面加:
var browserWindow = await Electron.WindowManager.CreateWindowAsync(new BrowserWindowOptions { Width = 1152, Height = 864, Show = true, Center=true, Transparent=true },$"http://localhost:{ BridgeSettings.WebPort }/1.html"); browserWindow.OnReadyToShow += () => browserWindow.Show(); browserWindow.SetTitle("Electron.NET API Demos");
我解释一下 $"http://localhost:{ BridgeSettings.WebPort }/1.html" ,这个URL参数就是你APP一打开的时候显示的页面。
BridgeSettings.WebPort就是获取你这个mvc绑定在本地的端口,可是跟你配置文件的端口可不同啊。
好比个人配置文件中指定mvc端口为50000,可是生成的时候端口可能倒是8000.
这时候程序上下文所指定的路径为:\你的项目\obj\Host\node_modules\.bin
d、写你的逻辑,就像写网站同样,所有写完,也测试完了,再开始改配置文件:
<ItemGroup> <DotNetCliToolReference Include="ElectronNET.CLI" Version="*" /> </ItemGroup>
DotNetCliToolReference节点改为上面的样子,由于要用到它的tool.
e、在你的程序包管理控制台中找到你项目路径,刚开始是在外面的,你得cd一下啊,啥样算进去?就是dir能看到你的program.cs就好了。
f、 而后此时,运行dotnet electronize init, 它给你生成一个electron.manifest.json文件。
g、 而后继续dotnet electronize start, 可能会报错,不要紧,只要控制台橘黄色方框不灭(运行中)那你就继续等,走两步,没病走两步...
别的电脑没这么报错,我家里的电脑就咔咔的冒红,我鸟都不鸟,demo照样像红太阳同样冉冉升起!
h、效果
这个是以前写的一个动态下雨的页面,水珠子好像被我改得不像了- -,另外文字不居中,实在抱歉- - 由于当时只会css3不太会css.......
有人以为不该该拿ElectronNET跟WPF比,XAML万岁。嗯呐,万岁,对。见仁见智,老衲涂个清静。
g、资源
更多例子在:https://github.com/ElectronNET/electron.net-api-demos 这个是各类各类C#例子代码,若是窗口不显示Show=false改为true试试。
那里面的例子是C#以及js对照的,js的明显没官网的全, 就算你看完例子也不必定能找到上面代码中的一些代码,由于我翻了点源码。毕竟是第一版,啥都慢慢来吧。
今儿的例子我传到:https://github.com/NMSLanX/ElectronNET.Demo
上了岁数了,时间和精力明显不够了,自顶而下的学习方法也成为了习惯。
不少类库的文档以及demo对于开发人员来讲就是天书,我历来不怪身边人说:"我看不懂,太难了,我不会。"
我从不侮辱他们的智商,若是有人不懂,那必定是做者以及团队的事,项目文档不够全面,demo的功能覆盖率低,同时也是生态中每一个人的失职!
下降学习成本是每一个.NET传教士义务与责任。
创建生态,保护生态,见者有份。