0.0.3 • Published 2 years ago

mmrc v0.0.3

Weekly downloads
-
License
MIT
Repository
-
Last release
2 years ago

MMRC - Main Method Renderer Call

mmrc is used to conveniently call methods/functions of the main process from within Electron's rendering process. mmrc uses asynchronous messages between the main/rendering feeds, without the potential problems associated with using remote. 中文文档在这里

Install

$ npm install --save mmrc

Usage

Main Process

  • Methods provided in the master process for the rendering process to call

    async function hello (message) {
        return `hello: ${message}`
    }

    Or

    function hello (message) {
        return new Promise((resolve, reject) => {
            resolve(`hello: ${message}`)
        })
    }
  • Create an instance of mmrc-main and register

    const { ipcMain } = require('electron')
    const MMRCMain = require('mmrc/main')
    // After you have finished creating the window instance
    const mmrcMain = new MMRCMain(ipcMain, win)
    mmrcMain.addMethod(hello, 'hello')

Renderer Process

  • Create an instance of mmrc-renderer and register

    const { ipcRenderer } = require('electron')
    const MMRCRenderer = require('mmrc/renderer')
    const mmrc = new MMRCRenderer(ipcRenderer)
  • Call the hello method of the main process

    mmrc.callMainMethod('hello', 'this is from renderer.').then(message => {
        console.log(message)
    }).catch(error => {
        console.log(error)
    })

    Will get the output, hello: this is from renderer.

    The first argument to mmrc.callMainMethod() is the name of the method to be called, the subsequent arguments are the parameters of the method to be called, and multiple arguments can be passed in.

    mmrc.C() method, which is a simplified name for mmrc.callMainMethod()

About the three "messages"

mmrc uses three messages 'mmrc.main.call.method', 'mmrc.renderer.done', 'mmrc.rendere.failed' as a way to communicate between the main process and the renderer process, so when you have your own message, keep it different from the three messages or use your own messages. As follows.

// main process
const mmrcMain = new MMRCMain(ipcMain, win, 'my.main.call', 'my.renderer.done', 'my.renderer.failed')

// renderer process
const mmrc = new MMRCRenderer(ipcRenderer, 'my.main.call', 'my.renderer.done', 'my.renderer.failed')

Just make sure that these three messages are not the same as yours.