粗麦百科 网站地图

当前位置: 首页 常识

桌面应用程序是什么(桌面版应用程序的前世今生)

100人浏览   2024-09-22 10:38:14

互联网出现之前,C/S架构是软件产品的主流,后面渐渐地被B/S架构所取代(因为不需要配置客户端),但由于浏览器有刷新机制,服务器的负载等因素,C/S架构的响应速度和流畅性是好于B/S架构的,所以现在软件开发的趋势是两者的融合,一般是B/S架构开发的产品可以非常方便地转移到C/S架构下。客户端(client)是C/S架构软件产品中重要的一部分,除了和用户交互、本地处理数据的强大功能,顺畅的体验和美观的样式也是客户端技术追求的目标。微策略的智能商务平台除了功能丰富的web终端,也推出了多位一体的强大桌面终端Workstation,旨在提供一站式的智能商务体验。这里和大家介绍桌面版应用程序的一些历史和现在比较流行的electron技术。




桌面版应用程序历史


桌面应用程序,又称为GUI程序。可以分为以下几个阶段:

  • VB, 上古程序员的开发工具,曾经全球第一的开发语言,拖拽式的图形化开发让它成为极佳的桌面开发工具。微软依靠其操作系统的优势,一直压制同时期的竞争对手delphi。微策略早期应用该技术,开发了管理智能商务平台的大杀器developer。
  • C++、win32API的MFC方案是基于窗口中组合控件和消息传递机制。这也是20多年前的技术,所以API设计的不是很友好。几年前微软已经停止维护,简单来说它已经过时了。
  • Winform 微策略几年前基于该技术研发第一代的Desktop版本,但是从开发体验角度来说自定义、美化控件会比较麻烦。
  • C# .net framework, 代表就是WPF,它的原生特性是其他类库无法比拟的:High DPI、Split Screen以及对DirectX的天然优势。但是并不开源,需要依赖.net框架,还有就是启动会比较慢。Workstation Windows的新客户端就是基于该技术研发。
  • Java swing/javaFx 这是一类比较大的阵营,优势是跨平台和流行开发语言java的天然结合, 但开发出来的界面作者个人认为并不美观。
  • C++ Qt,这是很多客户端跨平台的首选,因为开源、UI库和各种功能的类库非常丰富,但是学习成本比较高。
  • C++ duilib, 这是windows下开源的directUI(微软提出的分离UI和逻辑的思想)库,它是迎合互联网桌面软件小而美的趋势发展起来的,可能大家对它的关注度比较少。但是用它开发出的产品大名鼎鼎,比如QQ, 微信, 爱奇艺等很多知名度高的软件。
  • Objective-c/swift cocoa, 这是mac平台下的方案。可以方便调用底层的API,缺点是不跨平台,文档不友好,UI库并不丰富。现在这种方式开发的越来越少了。

基于web技术的桌面应用开发


从B/S和C/S架构逐渐融合的角度来说,基于web技术进行桌面程序的开发渐渐变成了主流。因为对界面的代码部分可以做到复用。


这类技术早期的方案是用vb内嵌webBrowser控件,基于IE内核,正好很多网页开发也有用activeX的需求,但这种方式具有明显的缺陷——非常依赖于用户的环境,会因为组件缺失导致程序各种崩溃。第二类是嵌入式网页框架,这类技术主要是基于浏览器引擎实现UI渲染。比较典型的就是appkit上面UIWebView和CEF(chromium embeded framework)。这种方法可以使用网页HTML5+CSS实现各种酷炫的效果,但是缺点也比较明显,就是桌面程序里面嵌入了一个类似chrome的浏览器,内存的开销会比较大。


后面出现了nwjs和electron,electron相比CEF有了单独执行js的v8引擎,可以运行nodeJS来完成服务器端功能,通过和内部浏览器的v8引擎交互可以实现一个独立的客户端,这不同于CEF需要寄宿在其他程序内部。


Electron




用Electron来做桌面程序开发的优势明显,相当于是完全的网页编程,有web开发经验的前端开发上手非常容易。Web开发生态广泛,开发成本低,可扩展性强,一些流行的前端框架例如React, Angular, Vue都可以和electron结合进行开发。另外它也具备和Qt一样跨平台的优良特性。对性能要求不高的桌面版程序来说,一份代码同时得到网页版和各个平台的桌面版,开发的效率是其他方案无法比的。可以说这是大部分人看好的趋势。

和web开发的区别

前端开发的一个痛点就是经常需要考虑多种浏览器之间的兼容,但是使用electron开发则不存在这样的问题,它只需要考虑electron中对应chrome的版本。另一个使用electron解决的痛点是跨域,它可以绕过客户端直接通过nodeJS里的request通信模块发出请求,这样就无需被跨域所困扰。

扩展能力

node-ffi可以在nodeJS环境中调用动态链接库接口。通过这种方式,我们可以把javascript方法映射到动态链接库接口,从而实现c++类库的接入。

Electron运行原理



Electron的运行机制可以从两种进程说起:主进程和渲染进程。运行package.json的称为主进程,它可以负责创建渲染进程(多个)。下图是一段主进程代码,主进程负责创建一个浏览器实例来加载网页。每个创建的浏览器实例都在它自己的渲染进程内返回一个web页面。当BrowserWindow实例销毁时,相应的渲染进程也会终止。主进程负责掌管所有的web页面和它们相应的渲染进程。每个渲染进程都是相互独立的,它们只关心自己所运行的web页面。

const electron = require('electron');
const app = electron.app;
const BrowserWindow = electron.BrowserWindow;

var window = null;
app.on('ready', function() {
 window = new BrowserWindow({width: 800, height: 600});
 window.loadURL('https://microstrategy.com');
});


主进程还负责应用程序的生命周期(app打开退出)和一些app事件的监听,同时负责系统底层API的调用。创建的渲染进程用来展示HTML + CSS技术编写的web页面, 同时可以运行javascript实现交互,可以把渲染进程简单理解为chrome上打开的一个浏览器进程。


<html>
 <body>
 <script>
 const remote = require('electron').remote;
 console.log(remote.app.getVersion());
 </script>
 </body>
</html>


在渲染进程中是不允许调用原生GUI相关的API,那是因为在网页中掌管原生GUI很危险,易造成内存泄露。如果你想在网页中进行GUI的操作,渲染进程必须向主进程传达请求,然后在主进程中完成操作。


Electron封装了一系列自己的API可供主进程和渲染进程调用。可以通过如下方式获取:


const {app, BrowserWindow, ipcMain, ... } = require('electron'); // 仅主进程可用
const {ipcRender, remote, ... } = require('electron'); // 仅渲染进程可用

主进程和渲染进程均可直接调用nodeJS的API

node1.addEventListener('click', () => {
 console.log(os.path.basename('xxxx');
})

进程通信

渲染进程如何向主进程发送消息


通信本质上基于nodeJS的事件基础类EventEmitter,ipcMain和ipcRender都是该类的实例,通过事件模型需要的接口方法,采用了发布/订阅的方式来发送和监听消息。


异步方式

import { ipcRender } from 'electron'; //在渲染进程引入ipcRender,它是EventEmitter的一个实例
ipcRender.send('async', 'I am from webview'); //可以异步发送


同步方式

import { ipcRender } from 'electron'; //在渲染进程引入ipcRender
ipcRender.sendSync('sync', 'I am sync sent from webview'); //同步方式

通过同步方式发送会block整个渲染进程,直到主进程响应。


主进程会加载ipcMain来进行监听


import { ipcMain } from 'electron'; //在主进程引入ipcMain
ipcMain.on('async', (event, info) {
 console.log(info);
});


除此以外, electron还提供了一种简单的方案(remote模块)来实现渲染进程和主进程的通信。这样就可以不必显示地发送消息。


import { remote } from 'electron'; //在渲染进程引入remote
remote.mainProcessObject.invokeMethod(); // 调用主进程才有的方法
});

主进程如何向渲染进程发送消息

主进程通过找到渲染进程对应的browserWindow就可以发送消息。

constant window = BrowserWindow.fromId(global.id); // 通过id来进行对应
window.webContents.send('msg', 'hello world');


渲染进程监听

ipcRender.on('msg', (event, info) => {
 console.log(info)
});

渲染进程之间共享数据


一种可行的方案是在主进程实现消息的转发。还有比较简单的方案是通过浏览器实现的HTML API,比如localStorage, sessionStorage或者IndexedDB。或者通过主进程创建全局变量sharedObject来实现渲染进程的数据共享。

以上是一些electron技术初步的介绍,有兴趣的读者可以继续阅读详细的官方文档来深入学习。目前来看electron不能算一个年轻的开源项目, 还有不少新的桌面替代技术在涌现(比如miniblink)。如何将像electron这样的优秀技术思想和微策略的桌面程序相结合将一直值得我们探索。

我们会每周推送商业智能、数据分析资讯、技术干货和程序员日常生活,欢迎关注我们的头条&知乎公众号“微策略中国”或微信公众号“微策略 商业智能"。

热门文章
  • 1八月十三是什么日子(军史上的今天|8月13日——淞沪会战)

    1937年8月13日淞沪会战爆发中日近百万军队血战淞沪战至最艰难阶段为掩护大部队撤离中国军队第88师262旅524团副团长谢晋元率400余孤军坚守四行仓库以寡敌众顽强抵抗四天四夜与此同时法国神父饶家驹设立南市难民区保护了大批中国难民为后来南京安全区的设立带来启发淞沪会战1937年8月13日至11月1

    2有关清明节的知识(“清明碰闰月,上坟三注意”要注意什么呢?)

    清明是传统的春祭节日,在清明扫墓祭祀、缅怀祖先,不仅有利于弘扬中华的孝道亲情,而且还能促进家族成员乃至民族的凝聚力和认同感,所以从古至今,清明节都是非常重要的一个节日。而今年的清明节和往年都不一样,因为今年清明处于闰二月,而在古人的认识中,闰二月属于一个霉运,在这个月做大部分的事情,都要格外注意,避

    3愉快假期朋友圈文案(“向生活请个假,周末愉快呀”)

    1²º²⁴/₁₁.₂₄ᴴᴬᵛᴱ ᴬ ᴳᴼᴼᴰ ᵀᴵᴹᴱ生活简简单单,日子温温柔柔,与万事言和,与独处相安,自行,自醒,自清,自爱,用好的心情去承揽今日好的运气。2²⁰²⁴/₁₁.₂₄♡Morning日子渺小重复,却很幸福。用心感受生活,心里有爱,每一天都是幸福的起点。3²⁰²⁴/₁₁.₂₄* ੈ✩‧

    4炒粉的家常做法,每个人都能学会

    海鲜炒粉干口味:★ ★ ★ ★ ★营养:★ ★ ★ ★★美感:★ ★ ★ ★ ★操作:★ ★ ★ ★ ☆配料:平阳粉干半扎、虾适量、墨鱼干适量、五花肉适量、胡萝卜适量、香菇7朵、包菜半个、鸡蛋1个、生抽一匙、白糖少许、盐适量、鸡精一匙、鲍鱼汁一匙烹饪步骤:1.虾去虾须清洗干净再去内脏(用虾干更好吃哦

    5煲鱼汤的做法大全(砂仁陈皮鲫鱼汤丨美食)

    为大家推荐一道靓汤:砂仁陈皮鲫鱼汤。原料:新鲜鲫鱼200克,砂仁3克,陈皮6克,生姜、葱、油、精盐适量。做法:1.将鲜鲫鱼刮去鳞、鳃,剖腹去内脏,用清水洗净,沥干水分待用。2.砂仁研末,塞入鱼腹内,用线缝合,置油锅慢火煎至两面微黄后放入砂锅。3.砂锅加适量水,大火烧开,放入陈皮、姜片、葱段,用文火炖

    6神司马懿技能介绍(三国杀神司马懿到底算不算四害?)

    在三国杀这个游戏里,除了魏蜀吴群四大势力之外,神这个势力就比较独特了。因为当玩家选出神势力武将之后,就可以自由选择魏蜀吴群四大势力。官方在当年设计这些神武将的时候,通常情况下也都是根据他们一生里最有名的事件或战役来设计对应的技能。比如说神赵云,长坂坡七进七出声名远扬,所以他的技能濒死和脱离濒死都能摸

    7五岳山在哪个省份(中国五岳是哪几座山?)

    ·一、东岳泰山。位于山东省泰安市,海拔1545米。古以来泰山就是中国文化的象征之一,被誉为&quot;五岳之首&quot;和&quot;天下第一山&quot;,因其雄伟的气势和丰富的文化历史而闻名。泰山的自然景观包括奇峰、深谷、瀑布等,而人文景观则涵盖了岱庙、红门宫等古迹,展现了中华民族的精神象征。·二、西岳华山。位于陕西省渭南市华阴市,

    8上饶旅游必去十大景点(上饶旅游必打卡的十大景点)

    最值得去的十个旅游景区。说说上饶旅游必打卡的十大景点!1. 去灵山风景名胜区,体验瀑布王国的壮丽,感受大自然的鬼斧神工。2. 去三清山,登上道教名山之巅,感受云雾缭绕的仙境。3. 去龟峰,探秘奇峰怪石的世界,感受大自然的鬼斧神工。4. 去葛仙山,体验道教文化的博大精深,感受人间仙境的宁静祥和。5.

    9口味重,敌不过好处多!但这几类人吃了反伤身

    大蒜、洋葱、香葱等,是很多菜品中的“配角”,因其“独特”的味道,喜欢的人,不管烹调什么都喜欢加一点,但也有不少人对它们敬而远之~不过,小编想告诉大家,这些葱类蔬菜可不仅仅是菜肴中的调味品,甚至有研究称它们对降低某些癌症风险有好处。葱类食物,或能成为“防癌帮手”?洋葱、大葱、香葱、大蒜、韭菜、蒜苗都属

    10花卷馒头的做法大全(8款家常做法)

    一直很喜欢做各种花式馒头,但是太复杂的造型又来不了,所以花卷和简单的馒头倒是做了很多次,家人也都特别喜欢吃。女儿更是表示以后不要再买馒头花卷了,哈哈,这大概是“厨娘”听到的最好点评了。这里豆妈就分享几款自己经常做到的花式馒头和花卷的做法,希望能对爱吃馒头花卷的你有所启发。首先馒头和花卷都是需要发面的
最新推荐
  • 冰箱为什么不能放热的东西(为了健康和安全,该把食物放凉了再进冰箱吗?)

    我们总有这样的时候,晚上肚子饿了,做好夜宵,可是最后吃剩下的饭菜直到睡前还没有完全冷下来;中午回家吃饭,吃剩的菜直到自己上班还没有冷下来等等,遇到这种情况,我们是否可以直接将热菜放进冰箱呢?答案是:不要犹豫,直接放入冰箱吧,而且趁热放进冰箱对抑制细菌可能更有用,因为可以使食物在“危险温度区间”存放时

    为什么家里不养莲花(这些花不能在家里养,养错了会让生活增加烦恼)

    鲜花能点缀我们的生活,绿叶能给房间带来色彩,每个人的房间里都会有各种各样的花,养花不仅能陶冶情操,还能放松我们的心情,让我们对生活充满着希望。养花虽然好处多,但不是所有的花都适合养在我们的室内房间,尤其是在我们睡觉的房间里,但大多数人都是把花放在阳台上,而阳台又和我们的卧室相连,也就是间接着在卧室一

    无线网为什么这么慢(为什么 WiFi 满格网络却很卡)

    WiFi信号满格但网络却很卡顿,存在以下几点可能致使的原因:·1.有多个设备同时连接到该WiFi,占用了大量带宽,导致网络拥堵。·2.路由器性能不足,无法处理大量的数据传输。·3.可能存在网络干扰,比如附近有其他同频段的WiFi信号或其他电子设备干扰。·4.上网设备自身问题,比如设备运行的程序过多等

    为什么要床垫(露营为啥一定要携带睡垫?)

    我们熟知的露营三件套,分别是帐篷,睡袋,睡垫,可见睡垫在露营过程中的重要性。不管是露营,登山,徒步,还是做别的,只要你要在户外搭帐篷过夜,那么你就需要睡垫。那么睡垫的作用是什么呢?东哥觉得主要有两点,1、保暖;2、防膈,户外的地面都是比较硬的,直接睡在地面上会非常不舒服,而睡垫就是我们在户外的床垫。

    为什么内开窗性能比外开窗性能好(内开窗和外开窗哪个好)

    装修时大部分户型都会涉及到封阳台装断桥铝或系统窗,那么此时你一定会面临这个选择——选内开窗还是外开窗?那么,内开窗和外开窗有什么区别?到底哪个好……作为过来人,这次我做给大家做一个全面细致的对比,供大家参考和交流:1.开关步骤对比:内开窗胜内开窗:直接打开,直接关闭。与外开相比,明显更为简单方便。外

    顶层房子为什么不好卖(为何聪明人都劝你别买顶楼?)

    为什么买房的时候,很多人都劝你别买顶楼呢?关于顶楼的一些坑,你又知道多少?其实,顶楼既有优点也有缺点,究竟如何选择,还是要看个人意愿,但对于我来说,顶楼的6个缺点,是我无论如何都难以接受的。话不多说,一起来看看吧~一、容易有漏水问题顶楼户型,尤其是一些老小区老房,漏水问题真的是屡见不鲜,没几年我就能

    建兰为什么不开花(建兰不开花的原因和解决方法)

    建兰为什么不开花,建兰是一种喜阴植物,植株的生长对光照的需求不高,但是不能长期将它放在阴暗的环境中,否则会导致植株发育不良,影响到植株的生长开花。养分是建兰生长的关键,植株的生长以及开花会消耗掉大量的养分,此时如果不能保证养分充裕,植株将无法正常的生长以及开花。一旦养分不足,则需要及时对其进行施肥,

    红掌为什么不开花(原来是这5点没做好,快及时改善)

    很多朋友都喜欢养红掌,它的叶子特别有光泽,叶片是心形的,最常见的品种花苞一般是深红色或橘红色的,有像蜡烛般的肉穗状花序,最受欢迎的花色就是“中国红”。很多人养不好盆栽红掌,很有可能就是对它还不够了解,就比如它的生长习性。红掌有很多别名,它的中文正式名叫“花烛”,也叫安祖花或蜡烛花。想要养好红掌,就要

    陶瓷为什么会开裂(揭秘瓷砖开裂的8种原因)

    01贴砖时不留缝或留缝过小瓷砖的收缩系数远比钢筋混凝土小,当出现热胀冷缩时,如果没有留缝或者留缝不足,基础层的伸缩较大,而瓷砖膨胀过慢,从而产生被拉裂的现象。裂缝纹理较小较短,其边角还可能出现崩裂。所以在铺贴瓷砖时,一定要注意留缝!02手工切割瓷砖造成暗裂工匠对瓷砖进行切割施工时可能由于操作不当造成

    电脑为什么键盘用不了(键盘突然失灵怎么办?)

    键盘没有反应了按哪个键?在日常使用电脑的过程中,我们难免会遇到键盘突然没有反应的情况,这时许多人可能会感到手足无措,不知道该如何解决。实际上面对键盘失灵的问题,首先不要慌张,可以尝试一些简单的方法来恢复键盘的正常工作。不过需要注意的是,并没有一个特定的&quot;神奇按键&quot;能够立即解决所有键盘失灵的问题。·当

网站内容来自网络,如有侵权请联系我们,立即删除!
Copyright © 粗麦百科 琼ICP备2024032622号-16