首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

NW.js构建跨平台桌面应用(1)-入门案例

NW.js的用途 NW.js 基于 Chromium 和 Node.js,从而可以在桌面app中使用浏览器开发技术并直接调用 Node.js 资源,甚至将一个web应用打包到本地也轻而易举。...安装NW.js 可以从官网下载; 推荐在开发时下载是sdk版,以使用DevTools 非sdk版也应同时下载,在发布时使用 写一个 Hello World!.../path/to/nw 是 NW.js 的二进制运行文件; 在Windows上是nw.exe,在Linux上是nw,而在Mac则是nwjs.app/Contents/MacOS/nwjs Linux和Mac...可能需要sudo提升运行权限 例如mac上用如下方式启动:sudo ~/nwjs/nwjs.app/Contents/MacOS/nwjs . ?...将第一步中下载的“非sdk版程序包的.zip文件”所在的目录,填入"Download location",并且不勾选"SDK build"选项 点击右下角的Export按钮,即可发布,默认路径是output mac

3.9K20
您找到你想要的搜索结果了吗?
是的
没有找到

NW.js构建跨平台桌面应用(2)-原生界面API

而前面提到的两者,要么无法访问GUI,要么受限于API边界,均无法提供 NW.js Native UI APIs 则在其他JS层的顶部提供了这些完整的功能 1.1 获取nw实例 旧版本中可以用 var...Window API - 操作NW.js窗口 在NW.js中,Window API 只不过是对DOM中window对象的一层包装,很多(并非所有)方法和属性继承了后者的用法,同时window对象也是 Node.js...(); other.hide();other.maximize(); other.unmaximize();other.focus(); 应成对使用以上方法并仔细测试,否则会在不同平台引起差异;比如在Mac...Menu API - 菜单栏和右键中的菜单 NW.js中,共有三种类型的菜单: 上下文菜单:右键单击应用内的元素时 窗口菜单:在Windows或Linux中,每个窗口上方都可以有自己的菜单栏;==在Mac...(这些图标在不同平台叫法不同,Mac中叫做 Status Item, 一些Linux中叫做 Status Icon, Windows 中叫做 System Tray Icon) // 创建一个托盘图标

6.4K40

NW.js构建跨平台桌面应用(3)-利用Node.js

Node.js常用来构建高并发的C/S应用,将这种模式移植到NW.js程序中虽然可行且费不了什么功夫,但仅仅这样做并不能发挥出平台所有的潜力;要知道NW.js允许直接在DOM中和Node.js交互,而这将大大加快程序的运行和简化开发...模块 内部模块 var fs = require('fs') 第三方模块 npm install 之后 var _ = require('underscore') C/C++ 模块 global对象 NW.js...process也是一个在窗口中和Node.js上下文中都可以访问到的全局对象 除了可以访问固有的 process.env.HOME 得到主目录等,还添加了如下属性: process.version['NW.js.../util').dirname;console.log( path.normalize('/my/folder') ); //Mac输出'/my/folder',Win输出'\\my\\folder'console.log...( path.join(dirname, 'data/my.json') ); //Mac输出'/xxx/myApp/data/my.json',Win输出'c:\\xx\\myApp\\data\\my.json

2.3K20

Electron升级构建适配M1芯片Mac指南

写在开头 由于最新的Electron已经支持了M1芯片,arm架构下的Mac 在开发桌面软件时候不可避免的需要打包自测,那么在M1芯片上的Mac打包适配自己的软件也是应该的 那么现在制作Electron...桌面软件,应该是适配linux,windows,mac os(x86架构,arm架构)四个系统环境 为什么写这个文章 我使用的一些软件,竟然现在还不支持arm架构的Mac,更新速度太慢了,明明都是依赖Electron...,其实大部分软件升级适配成本不高,桌面软件开发者们赶紧升级吧 背景 Electron不支持xp系统,只要node.js升级后基本上它就会发布升级版本(如果你要兼容xp系统请使用nw.js等) 目前node.js...最新版本15.x已经适配了arm架构下的Mac,electron11.0.0版本也已经支持在arm架构下的Mac运行了,我需要在自己电脑上自测自己开发的软件兼容性,所以这次需要升级Electron版本和各种插件等...的值: “mac”: { "target": { "target": "dmg", "arch": [ "arm64",

2.5K20

桌面软件开发框架大赏

这也直接导致GTK的维护者很重视Linux领域的发展,而忽视Windows和Mac领域。 这个框架提供的很多API,只在Linux下有,Windows和Mac下没有。这样的API数量众多。...flutter-desktop https://docs.flutter.dev/desktop​ 这是谷歌的跨平台开发框架,开源、免费、文档齐全、投入力度大且持久, 桌面端同样也新的很,Windows版本刚刚发稳定版,Mac...zhuanlan.zhihu.com/p/428560381 webview https://github.com/webview/webview 这个库使用操作系统的浏览器引擎来达到减小安装包体积的问题, Mac...webview框架碰到的问题TAURI都有, 使用Rust开发,将来会支持Deno,作者说将来会直接使用webview的技术来支持多平台, NW.js https://nwjs.io/ NW.js最早把...NW.js基于MIT开源,可以无忧使用。 微信小程序开发工具是用NW.js开发的。作者是英特尔的员工,英特尔的一些工具也是用NW.js开发的。

6.7K30

electron 构建跨平台桌面应用

昨日(2016.09.13)本文发表后,获得了一定的阅读和转发量,但经部分网友反馈和仔细审核后发现,在与 NW.js 对比的环节,言辞欠妥,且数据的真实性有待考究,特此将争议部分删除,同时借此诚挚地向...NW.js 的作者以及各位读者反馈表示感谢,期待更多深入的交流和分享,修订后的版本如下: Stack Overflow 联合创始人 Jeff Wood 曾说过,任何一个能用 JavaScript 编写的应用系统...简单地说,通过 Electron,我们可以使用自己所熟悉的前端技术轻松构建出一款能运行在Windows, Linux 和 Mac 上的桌面级应用程序。...其他 当然 Electron 中还有许多实用的模块,如作为桌面应用必不可少的 Menu 和 Tray 模块、拥有调用当前操作系统功能的 Shell 模块、NW.js 中不具备的自动更新功能 - autoUpdater...npm run build-mac 最后贴一张最近利用 Electron 构建的桌面版豆瓣FM的截图: ?

3.4K110

打算一个卡片记忆软件,全平台架构如何选型?

产品期望 支持全平台,包括Windows、Mac、Linux、Android、iOS、Web和鸿蒙。...Windows, macOS, Linux 中等 HTML, CSS, JavaScript 社区支持 一般 中等 NW.js社区 中等 较大 较大 高 性能相对其他框架较低,内存占用高 中等 NW.js...nw.js NW.js(以前称为Node-Webkit)是一个基于Chromium和Node.js的框架,用于构建跨平台的桌面应用程序。...NW.js具有以下特点: 跨平台支持:NW.js可以在多个操作系统上运行,使开发者能够使用相同的代码库构建跨平台的桌面应用程序。...然而,NW.js也存在一些挑战,包括: 性能相对其他框架较低:由于NW.js同时运行Chromium和Node.js,可能导致一些性能方面的挑战,例如初始启动时间较长和内存占用较高。

26810

Mac | Mac 系统的恢复

在执行操作前,确保有网络环境,且 Mac 电脑已经连接到网络。 1.1. 确定CPU架构 即确定 CPU 是 Intel 的还是 Apple 自家的。两者在触发恢复时的热键不一致。...执行操作过程中,不要将 Mac 置于睡眠状态或合上上盖。...上,您可以在启动时使用 Shift-Option-Command-R 来获得 Mac 自带的 macOS,或与它最接近且仍在提供的版本。...或者,您也可以在启动时使用 Option-Command-R 来获得与 Mac 兼容的最新版 macOS;在某些情况下,也可获得 Mac 自带的 macOS 或与它最接近且仍在提供的版本。...如果刚刚更换过 Mac 主板,您可能只会获得与 Mac 兼容的最新版 macOS。 如果刚刚抹掉了整个启动磁盘,您可能只会获得 Mac 自带的 macOS,或与它最接近且仍在提供的版本。

2.2K40
领券