React + electronjs 实现桌面软件开发引入 electronjs 及 node api

Posted 夏秋初的学习笔记

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了React + electronjs 实现桌面软件开发引入 electronjs 及 node api相关的知识,希望对你有一定的参考价值。

React 与 electronjs 安装及运行请百度。

electronjs中引入 React

// electronjs 目录下的 main.js,loadFile修改为 loadURL
// mainWindow.loadFile(‘index.html‘)
mainWindow.loadURL("http://localhost:3000/");
// electronjs 目录下的 preload.js 最底下追加
// load Api 需要什么 api 就引入什么api
const loadApi = [
  ‘electron‘, // 引入 electronmysql‘, // 引入 mysql
];
loadApi.map((item)=>{
  global[item] = require(item);
});

React中调用 preload.js文件中暴露的 api

import React,{Component} from ‘react‘;
import { HashRouter as Router, Link, Route } from ‘react-router-dom‘;
import ‘./App.css‘;
import { Button } from ‘element-react‘;
const Home = () => (
  <div>
    <h2>Home</h2>
  </div>
)

const About = () => (
  <div>
    <h2>About</h2>
  </div>
)

const Product = () => (
  <div>
    <h2>Product</h2>
  </div>
)
// const electron = window.electron
class App extends Component {
  Test(){
   
  }
  render(){
     const { electron } = window.electron;
    // console.log(window.electron);
    return (
      <Router>
          <div className="App">
            <Link to="/">Home</Link>
            <Link to="/About">About</Link>
            <Link to="/Product">Product</Link>
            <hr/>
            <Route path="/" exact component={Home}></Route>
            <Route path="/about" component={About}></Route>
            <Route path="/product" component={Product}></Route>
          </div>
        </Router>
    )
  }
}

export default App;

 

以上是关于React + electronjs 实现桌面软件开发引入 electronjs 及 node api的主要内容,如果未能解决你的问题,请参考以下文章

将PortQry与ElectronJS桌面应用程序集成

使用 Electronjs/SerialPort 和 React/Redux 的数组绑定

我怎么能通过手写在我的 Electronjs 桌面应用程序上写一些东西[关闭]

如何更改 ElectronJS 应用程序的默认图标?

使用Electronjs / SerialPort和React / Redux进行数组绑定

如何将 Python + Electron JS 编译成桌面应用程序(exe)