我们相信:世界是美好的,你是我也是。平行空间的世界里面,不同版本的生活也在继续...

本文说一下electrondialog组件中的messagebox,注意:本文提及的对话框组件是系统原生的组件,并不是各种模拟出来的那种。因为调用的是系统原生组件,不同的系统里面的表现样式,也是不一样的。特别是win10中,这个对话框的效果,真心是一如既往的难看,苏南大叔表示很无奈啊。

苏南大叔:electron dialog组件:如何调用对话框messagebox组件? - electron-dialog
electron dialog组件:如何调用对话框messagebox组件?(图9-1)

本文的测试环境,macwin10

基本效果

基本效果如下:
mac:

苏南大叔:electron dialog组件:如何调用对话框messagebox组件? - dialog-mac
electron dialog组件:如何调用对话框messagebox组件?(图9-2)

win10:

苏南大叔:electron dialog组件:如何调用对话框messagebox组件? - dialog-win10
electron dialog组件:如何调用对话框messagebox组件?(图9-3)

centos:

苏南大叔:electron dialog组件:如何调用对话框messagebox组件? - dialog-centos
electron dialog组件:如何调用对话框messagebox组件?(图9-4)

基本代码

写在主进程中,基础demo代码是:

const {dialog,shell,nativeImage} = require('electron');
dialog.showMessageBox({
  title: "帮助",//信息提示框标题
  message: "是否愿意给苏南大叔买瓶橙汁?",//信息提示框内容
  buttons: ["愿意", "不愿意", "不知道"],//下方显示的按钮
  noLink:true, //win下的样式
  type: "error",//图标类型
  //type: "info",//图标类型
  //icon:nativeImage.createFromPath("./icon/png.png"),//图标
  cancelId:2//点击x号关闭返回值
}, function (index) {
  console.log(index);
});

参数说明

electrondialog里面的MessageBox组件,有很多参数,其中最简化的操作就是:仅仅使用titlemessage两个参数。更多的参数说明,请参见:

类型及图标

首先,默认图标是由type决定的,但是自己可以通过icon来进行指定。苏南大叔个人建议:使用icon个人指定,主要的理由是:type的定义是固定的几个值,并且不同的系统下表现图标并不一致。icon直接指定图标的话,是更加靠谱一些。

type: "info",

主要取值有:none/info/error/question/warning

注意:

  • win10下指定type不指定icon,图标会根据type的不同而改变。
  • mac下指定type不指定icon,图标恒定是默认的electron图标。
  • centos下指定type不指定icon,图标是恒定不显示的。

苏南大叔:electron dialog组件:如何调用对话框messagebox组件? - dialog-centos-icon
electron dialog组件:如何调用对话框messagebox组件?(图9-5)

icon:nativeImage.createFromPath("./icon/png.png"),

注意:

  • 这里的图标地址就是普通的图片,比如最常见的png图标,并不是.ico文件或者.icns文件,也就是说套娃图的说法,在这里是并不成立的。
  • 另外,nativeImage是需要额外引用的,如下所示:
const {nativeImage} = require('electron');

图标的情况,总结如下:

newsn.net:这里是【评论】可见内容

按钮及返回值

可以定义无数多个按钮,写到buttons数组里面即可。不过,win10界面上,按钮是上下排列的,真心是难看。mac上面左右排列,但是出现三个及以上按钮的时候,位置也是非常的丑。还不如win10上面的上下排列好看些。整体来说,还是centos下,效果最好看。

buttons: ["愿意", "不愿意", "不知道"],//下方显示的按钮

每个按钮的返回值就是其对应的索引值,顺序依次为:0/1/2 等等。

dialog.showMessageBox({
  //...
}, function (index) {
  console.log(index);
});

默认返回值,也就是上述的0/1/2等值中的某个一值。比如点击对话框的关闭按钮的时候,这个时候有个返回值。但是,目前来看,win10上,对话框是有关闭按钮的。在mac上,并不存在对应的关闭按钮。所以,cancelId对于mac或者centos来说,也是个多余的设置。

cancelId:2

提示文字标题及正文

提示文字分为两部分,一部分是标题title,另外一部分是正文message,比较好理解。其中,一个小小的提示就是:message中,需要进行换行的话,可以使用\r之类的换行符即可。

title: "帮助",//信息提示框标题
message: "是否愿意给苏南大叔买瓶橙汁?\r谢谢~",//信息提示框内容

这里需要注意的是:messagetitle只接收字符串类型,必要的话,可能需要您做个字符串强制转化。

Uncaught Exception:
Error: Message must be a string
at Object.showMessageBox

苏南大叔:electron dialog组件:如何调用对话框messagebox组件? - dialog-error-must-be-string
electron dialog组件:如何调用对话框messagebox组件?(图9-6)

window下的样式

大家可能注意到了,window下的样式,是足够丑陋的。那么如何才能改变这种上下布局的按钮排列方式呢?答案就是:

noLink:true

本参数尽在window下生效,为true的时候,显示传统样式(也就是大家更接受的类型)。为false的时候,显示更加现代化设计的弹框样式。

苏南大叔:electron dialog组件:如何调用对话框messagebox组件? - dialog-nolink-true
electron dialog组件:如何调用对话框messagebox组件?(图9-7)

苏南大叔:electron dialog组件:如何调用对话框messagebox组件? - dialog-nolink-false
electron dialog组件:如何调用对话框messagebox组件?(图9-8)

dialog的创建时机

这个dialog的相关代码,从表现上来说,应该是个表现层上面的东西。但是在本文中是用在主进程中的。所以,实际上是有个限制的,比如必须在appready事件之后调用。错误提示信息如下:

Uncaught Exception:
Error: dialog module can only be used after app is ready
at checkAppInitialized

苏南大叔:electron dialog组件:如何调用对话框messagebox组件? - dialog-error-app-ready
electron dialog组件:如何调用对话框messagebox组件?(图9-9)

可能存在的问题

在苏南大叔的测试中,对于连弹几个messagebox的情况:

  • 首先,messagebox之间没有阻塞关系,这个和传统的alert不一样。
  • 其次,有messagebox丢失的情况发生,有计算错误的情况发生,这个是有些匪夷所思的,大家可以自行尝试。

总结

这个对话框MessageBox,从名字上来看,很VB。不过,vb的时候过去很多年了,在electron的世界里面,大家就重新认识这个单词吧。哈哈哈~

更多electron相关文章咨询,请点击:

如果本文对您有帮助,或者节约了您的时间,欢迎打赏瓶饮料,建立下友谊关系。
本博客不欢迎:各种镜像采集行为。请尊重原创文章内容,转载请保留作者链接。

 【福利】 腾讯云最新爆款活动!1核2G云服务器首年50元!

 【源码】本文代码片段及相关软件,请点此获取更多信息

 【绝密】秘籍文章入口,仅传授于有缘之人   electron