一、快速搭建一个electron 项目结构

  1. # 克隆示例项目的仓库
  2. $ git clone https://github.com/electron/electron-quick-start
  3.  
  4. # 进入这个仓库
  5. $ cd electron-quick-start
  6.  
  7. # 安装依赖并运行
  8. $ npm install && npm start

二、关于<webview> 标签 的使用

<webview> 标签 可以把一个第三方页面嵌入到你的应用中,在一个最简单的 webview 中,它包含了 web page 的文件路径和一个控制 webview 容器展示效果的css样式:

  1. <webview id="foo" src="https://www.github.com/" style="display:inline-block; width:640px; height:480px"></webview>

如何获取 <webview></webview> 标签嵌入第三方网页的DOM元素

1、在 <webview> 标签 内使用 preload 属性指定声明该标签的js文件

  1. <webview src="https://wx2.qq.com/?&lang=zh_CN" autosize="on" minwidth="576" min-height="800" id="foo" preload="./inject.js"></webview>

2、定义<webview>  标签声明的js文件内容,是一个大的对象

  1. inject.js文件:
  1. webViewFunction = {
  2. getDom:function(){
  3. var a = document.getElementById('chatRoomMember.html')
  4. console.log(a)
  5. }
  6. }

3、在渲染进程js文件中调用, 调用的方式必须为对象形式

  1. onload = function(){
  2. var webview = document.getElementById('foo'); // 找到页面上的webview对象
  3.  
  4. webview.addEventListener("dom-ready", function(){
  5. // 打开webview 的调试窗口
  6. webview.openDevTools()
  7. webview.executeJavaScript('webViewFunction.getDom()') // 调用webview里的方法
  8. });
  9. }

如何调用 <webview>  标签的各个方法:必须在webview加载完之后调用

获取到页面上的<webview>  标签对象,在<webview>  标签加载完成之后进行调用

  1. var webview = document.getElementById('foo'); // 找到页面上的webview对象
  2.  
  3. webview.addEventListener("dom-ready", function(){
  4. // 打开webview 的调试窗口
  5. webview.openDevTools()
  6.  
  7. console.log(webview.getURL()) // 获得webview 的URl
  8. });

关于 <webview>.loadURL(url[, options]) 方法:重新载入一个新的url

如何绑定<webview>  标签的各个DOM事件:

获取到页面上的<webview>  标签对象,使用 addEventListener 进行绑定事件

  1. onload = function(){
  2. var webview = document.getElementById('foo'); // 找到页面上的webview对象
  3.  
  4. webview.addEventListener("dom-ready", function(){ // 绑定加载完后事件
  5. webview.openDevTools()
  6. });
  7.  
  8. webview.addEventListener("did-stop-loading", function(){ // 绑定加载结束时的事件
  9. console.log('载入结束')
  10. });
  11. webview.addEventListener("did-start-loading", function(){ // 绑定开始载入时事件
  12. console.log('开始载入')
  13. })
  14.  
  15. }

三、主进程和渲染进程之间的通讯

ipcMain 模块: 在主进程引入,用于接收渲染进程发射的事件和进行回复  
       结构: ipcMain.on ( 接收事件名, callback (事件对象,接收参数) )
 
  1. const {ipcMain} = require('electron')
  2.  
  3. ipcMain.on('send',function(event, data){ // 使用 ipcMain 模块接收渲染进程发射的事件
  4. console.log(data)
  5. event.sender.send('reply', '接收到事件后进行回复') // 发射回复事件
  6. })
ipcRenderer 模块: 在渲染进程引入,用于发射事件给主进程和接收主进程返回的回复事件
         结构:ipcRenderer.send ( 事件名称,发射的数据)
            ipcRenderer.on ( 回复事件名称,回复的数据)
 
  1. const {ipcRenderer} = require('electron')
  2.  
  3. ipcRenderer.send('send','发送数据')       // 使用 ipcRenderer 模块,发送事件给主进程
  4. ipcRenderer.on('reply', (event, data) => { // 接收主进程的回复事件
  5. console.log('主进程回复过来的数据'+data)
  6. })

四、两个渲染进程之间的通讯方法

在两个网页(渲染进程)间共享数据最简单的方法是使用浏览器中已经实现的 HTML5 API,比较好的方案是用 Storage API, localStoragesessionStorage 或者 IndexedDB

还可以用 Electron 内的 IPC 机制实现。将数据存在主进程的某个全局变量中,然后在多个渲染进程中使用 remote 模块来访问它

  1. // 在主进程中
  2. global.sharedObject = {
  3. someProperty: 'default value'
  4. };
  1. // 在第一个页面中
  2. require('remote').getGlobal('sharedObject').someProperty = 'new value';
  1. // 在第二个页面中
  2. console.log(require('remote').getGlobal('sharedObject').someProperty);

五、在主进程main.js文件中可使用的模块

 app 模块:          控制整个应用的生命周期设计

autoUpdater 模块:      自动更新应用

BrowserWindow 模块:     创建一个浏览器窗口

contentTracing 模块: 收集由底层的Chromium content 模块 产生的搜索数据

dialog 模块:       提供一个弹出框或者文件选择框

globalShortcut 模块:       注册全局的自定义快捷键

ipcMain 模块:       提供主进程和渲染进程之间的通讯方法,接收渲染进程发射过来的事件和数据并进行回复

menu 模块:       创建鼠标右键显示菜单,跟 menuItem模块 配合使用,可以通过 remote 模块给渲染进程调用.

powerSaveBlocker 模块: 阻止应用系统进入睡眠模式,允许应用保持系统和屏幕继续工作

session 模块:      创建一个新的 Session 对象. 可为应用创建多个Cookie文件夹存储不同的数据信息,并且不会相互影响,各自独立

webContents模块 :     是一个 事件发出者,负责渲染并控制网页,也是 BrowserWindow 对象的属性.  可设置打开调试窗口等

六、在渲染进程中可使用的模块

desktopCapturer 模块: 获取可用资源,这个资源可通过 getUserMedia 捕获得到.

ipcRenderer 模块:   提供渲染进程个主进程之间的通讯方法,可以从渲染进程向主进程发送同步或异步消息. 也可以收到主进程的相应.

 remote 模块:      使渲染进程可以调用主进程的模块

webFrame 模块:     自定义如何渲染当前网页

七、两个进程间都可以使用的模块

clipboard 模块:     提供方法来供复制和粘贴操作

crashReporter 模块 : 开启发送应用崩溃报告,自动提交崩溃报告给服务器

nativeImage 模块:   图片对象,从剪切板中读取图片,它返回的是 nativeImage

screen 模块 :      屏幕的 size,显示,鼠标位置等的信息. 即可根据用户显示器大小等信息进行渲染页面

shell 模块 :        提供了集成其他桌面客户端的关联功能,比如调用用户默认浏览器打开一个新窗口等

相关文档链接参考:https://www.w3cschool.cn/electronmanual/electronmanual-electron-faq.html

         https://electronjs.org/docs

electron 学习笔记的更多相关文章

  1. Electron学习笔记(一)

    Electron是使用Javascript.HTML5技术构建跨平台桌面应用的技术,是目前非常活跃的一项技术,其中比较有名气的应用有微软的VS Code. 创建一个Electron应用的方式有很多,G ...

  2. 关于Markdown的一些学习笔记

    **关于Markdown的一些学习笔记** 一直利用markdown进行博客的文档编写,一方面是因为不需要特别注重排版,另一方面是十分的方便.最近突发奇想的认为,如果能运用到平时的作业或课程中,会不会 ...

  3. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  4. PHP-自定义模板-学习笔记

    1.  开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2.  整体架构图 ...

  5. PHP-会员登录与注册例子解析-学习笔记

    1.开始 最近开始学习李炎恢老师的<PHP第二季度视频>中的“章节5:使用OOP注册会员”,做一个学习笔记,通过绘制基本页面流程和UML类图,来对加深理解. 2.基本页面流程 3.通过UM ...

  6. 2014年暑假c#学习笔记目录

    2014年暑假c#学习笔记 一.C#编程基础 1. c#编程基础之枚举 2. c#编程基础之函数可变参数 3. c#编程基础之字符串基础 4. c#编程基础之字符串函数 5.c#编程基础之ref.ou ...

  7. JAVA GUI编程学习笔记目录

    2014年暑假JAVA GUI编程学习笔记目录 1.JAVA之GUI编程概述 2.JAVA之GUI编程布局 3.JAVA之GUI编程Frame窗口 4.JAVA之GUI编程事件监听机制 5.JAVA之 ...

  8. seaJs学习笔记2 – seaJs组建库的使用

    原文地址:seaJs学习笔记2 – seaJs组建库的使用 我觉得学习新东西并不是会使用它就够了的,会使用仅仅代表你看懂了,理解了,二不代表你深入了,彻悟了它的精髓. 所以不断的学习将是源源不断. 最 ...

  9. CSS学习笔记

    CSS学习笔记 2016年12月15日整理 CSS基础 Chapter1 在console输入escape("宋体") ENTER 就会出现unicode编码 显示"%u ...

随机推荐

  1. datatable使用笔记

    这是一个使用datatable的jsp文件实例,实现了点击单元格后编辑单元格所在行的内容. <%@ page pageEncoding="UTF-8"%> <!D ...

  2. K:java中的序列化与反序列化

    Java序列化与反序列化是什么?为什么需要序列化与反序列化?如何实现Java序列化与反序列化?以下内容将围绕这些问题进行展开讨论. Java序列化与反序列化 简单来说Java序列化是指把Java对象转 ...

  3. 基于编辑距离来判断词语相似度方法(scala版)

    词语相似性比较,最容易想到的就是编辑距离,也叫做Levenshtein Distance算法.在Python中是有现成的模块可以帮助做这个的,不过代码也很简单,我这边就用scala实现了一版. 编辑距 ...

  4. h5拖拽上传图片

    h5实现拖拽上传图片 本文将为大家介绍如何通过js实现拖拽上传图片. 首先我们要禁用调浏览器默认的拖拽事件: window.onload = function(){ //拖离 document.add ...

  5. Java容器---Map基础

    1.Map API (1)Map 集合类用于存储元素对(称作"键"和"值"),其中每个键映射到一个值. java.util Interface Map<K ...

  6. socket对象放在一个datagridview的row的tag里面在拿出来 为什么是已释放

     socket对象放在一个datagridview的row的tag里面在拿出来 为什么是已释放 

  7. MicroPython之TPYBoard v102开发板控制OLED显示中文

    转载请以链接形式注明文章来源,公众号:MicroPython玩家汇 0x00前言 之前看到一篇文章是关于TPYBoardv102控制OLED屏显示的,看到之后就想尝试一下使用OLED屏来显示中文.最近 ...

  8. springboot mybatis 事务管理

    本文主要讲述springboot提供的声明式的事务管理机制. 一.一些概念 声明式的事务管理是基于AOP的,在springboot中可以通过@Transactional注解的方式获得支持,这种方式的优 ...

  9. css实现椭圆、半椭圆

    一.自适应的椭圆 1. 椭圆 css .ellipse{ width: 250px; height: 150px; margin: 50px; background: #FFD900; border- ...

  10. Java中的String类能否被继承?为什么?

    不能被继承,因为String类有final修饰符,而final修饰的类是不能被继承的. Java对String类的定义: public final class String implements ja ...