electron 网页和主进程通讯

本文介绍了一种在Electron应用中利用RxIPC进行AJAX调用的方法,通过将请求发送到主进程并由主进程使用Axios发起网络请求,实现了前后端分离的环境下对网络资源的有效访问。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前端网页

import {
  RxIpc
} from 'rx-ipc-electron/lib/rx-ipc';

export const IsElectron = window.navigator.userAgent.toLowerCase().indexOf('electron') !== -1;

export function ajax(config) {
  if (!IsElectron) return Promise.reject('only for electron');

  const {
    ipcRenderer
  } = eval(`require('electron')`);
  const rxIpc = new RxIpc(ipcRenderer);

  return new Promise((resolve, reject) => {
    rxIpc.runCommand('ajax', null, config).subscribe(resolve, reject);
  });
}

window['test1'] = async function test1() {
  const url = 'https://www.baidu.com/s';

  const params = {
    wd: 1
  };

  const rsp = await ajax({
    url,
    method: 'get',
    params,
  });

  console.log(rsp);
}

electron进程

import rxIpc from 'rx-ipc-electron/lib/main';
import { Observable } from 'rxjs';
import axios from 'axios';

rxIpc.registerListener('ajax', config => {
  return Observable.from(axios(config));
});
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值