精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

使用Electron打造跨平臺程序需要關注的技術點

開發 前端
Electron Forge可以被認為是Electron Builder的替代品,后者在應用程序構建和發布方面實現了相同的用例。這兩個項目在理念上的關鍵區別在于,Electron Forge專注于將現有的官方工具組合成一個單一的構建管道,而Builder則為大多數構建任務重寫自己的內部邏輯。

背景

上篇文章已經介紹了使用electron forge+vite+vue3來實現一個桌面應用程序的框架。本文重點介紹完善一個這樣的框架的幾個通用的需求點及實現方式。

需求

  • 實現客戶端在線升級
  • 實現與本地操作系統的交互
  • 實現配置信息持久化
  • 國際化配置
  • 實現跨域訪問

實現客戶端在線升級

update.js

const {app,dialog,autoUpdater} = require('electron');
const log = require("electron-log")
autoUpdater.logger = log
autoUpdater.logger.transports.file.level = "info"

const server = 'https://update.electronjs.org'
const url = `${server}/dongluyang/intel-desktop-app/${process.platform}-${process.arch}/${app.getVersion()}`

autoUpdater.setFeedURL(
  { 
    url:url
  } 
)


autoUpdater.on('checking-for-update', () => {
    log.info("獲取版本信息")
})

autoUpdater.on('update-not-available', () => {
    log.info("沒有可更新版本")
})

autoUpdater.on('update-available', ()  => {
    log.info("發現新版本")
})

autoUpdater.on('update-downloaded', (event, releaseNotes, releaseName, releaseDate, updateUrl, quitAndUpdate) => {
    dialog.showMessageBox({
        type: 'info',
        title: '軟件更新',
        message: "發現新版本"+releaseName+", 確定安裝?",
        detail: process.platform === 'win32' ? releaseNotes : releaseName,
        buttons: ['確定', '取消']
      }).then(returnValue => {
        if (returnValue.response === 0)  autoUpdater.quitAndInstall()
      })
  })

autoUpdater.on('error', (message) => {
    log.error('There was a problem updating the application')
    log.error(message)
})
  
export default autoUpdater

main.js

import autoUpdater from './update'

const createWindow = () => {
  // Create the browser window.
  mainWindow = new BrowserWindow({
    width: 800,
    height: 600,
    webPreferences: {
      preload: path.join(__dirname, 'preload.js'),
    },
  });
  // and load the index.html of the app.
  if (MAIN_WINDOW_VITE_DEV_SERVER_URL) {
    mainWindow.loadURL(MAIN_WINDOW_VITE_DEV_SERVER_URL);
  } else {
    mainWindow.loadFile(path.join(__dirname, `../renderer/${MAIN_WINDOW_VITE_NAME}/index.html`));
  }
  // Open the DevTools.
  mainWindow.webContents.openDevTools();
  mainWindow.once('ready-to-show', () => {
     autoUpdater.autoDownload = false
     autoUpdater.checkForUpdates()
 });

};

優缺點比較

方案

優點

缺點

本方案

實現簡單,和electron-forge集成容易。electron-forge有豐富的插件生態

  1. 只有update-downloaded事件,沒有進度更新的事件。
  2. 無法選擇安裝路徑
  3. 安裝過程丑了一點,是一個動態gif

electron-builder + electron-updater的autoUpdater

  1. 有download-progress事件,可以實現下載進度顯示。
  2. 不可以選擇安裝路徑

1.實現稍微比上述方案復雜。

2.官方推薦electron-forge打包,與主流技術分叉。

Electron Forge可以被認為是Electron Builder的替代品,后者在應用程序構建和發布方面實現了相同的用例。

這兩個項目在理念上的關鍵區別在于,Electron Forge專注于將現有的官方工具組合成一個單一的構建管道,而Builder則為大多數構建任務重寫自己的內部邏輯。

使用Forge有兩個主要優勢:

Forge一旦在Electron中得到支持,就會接收用于應用程序構建的新功能(例如ASAR完整性或通用macOS構建)。這些功能是在考慮到官方Electron工具的情況下構建的,因此Forge在發布后立即收到它們。

Forge的多包體系結構使其更易于理解和擴展。由于Forge由許多職責明確的較小包組成,因此更容易遵循代碼流。此外,它的可擴展API設計意味著您可以編寫自己的構建邏輯,而不必為高級用例提供配置選項。

運行界面

日志查看

運行期間,有錯誤,可以及時查看內容,日志地址是:

windows: C:\Users\%USERPROFILE%\AppData\Roaming\你的工程\logs。

mac: ~/Library/Application Support/你的工程 或者 ~/Library/Logs/你的工程。

實現與本地操作系統的交互

preload.js

在這個問題中可以暴露一些接口,這些接口可以在前端頁面調用,例如下面的就可以在前端vue頁面調用window.versions.node調用node方法。

const { contextBridge, ipcRenderer } = require('electron')

contextBridge.exposeInMainWorld('versions', { 
  node: () => process.versions.node, 
  chrome: () => process.versions.chrome, 
  electron: () => process.versions.electron, 
  ping: () => ipcRenderer.send('ping') ,
  pong: () => ipcRenderer.invoke('pong') 
})

main.js

通過ipcMain來處理。

async function handlePing (event, keyword) {
  const webContents = event.sender
  const win = BrowserWindow.fromWebContents(webContents)
  win.setTitle(keyword)
}


// This method will be called when Electron has finished
// initialization and is ready to create browser windows.
// Some APIs can only be used after this event occurs.
app.on('ready', ()=>{
  ipcMain.on('ping', handlePing)
  createWindow()
});

運行效果

總結

方向

解釋

對應元語

單向

ipcRender向ipcMain發送消息

ipcRender.send與ipcMain.on

雙向

ipcRender向ipcMain發送消息,并等待結果

ipcRender.invoke與ipcMain.handle

國際化配置

src/renderer/App.vue。

配置默認中文顯示。

<template>
 <a-config-provider :locale="locale">
    <router-view />
 </a-config-provider>
</template>

<script setup>
import { computed,ref } from 'vue';
import enUS from '@arco-design/web-vue/es/locale/lang/en-us';
import zhCN from '@arco-design/web-vue/es/locale/lang/zh-cn';
import useLocale from './hooks/locale';

const { currentLocale } = useLocale();

const locale = computed(() => {
  switch (currentLocale.value) {
    case 'zh-CN':
      return zhCN;
    case 'en-US':
      return enUS;
    default:
      return zhCN;
  }
});
const percentage = ref(0);
const showProgressBar = ref(false);
</script>

src/render/hooks/locale.js。

import { computed } from 'vue';
import { useI18n } from 'vue-i18n';
import { Message } from '@arco-design/web-vue';

export default function useLocale() {
  const i18 = useI18n();
  const currentLocale = computed(() => {
    return i18.locale.value;
  });
  const changeLocale = (value) => {
    if (i18.locale.value === value) {
      return;
    }
    i18.locale.value = value;
    localStorage.setItem('arco-locale', value);
    Message.success(i18.t('navbar.action.locale'));
  };
  return {
    currentLocale,
    changeLocale,
  };
}

src/render/main.js。

import { createI18n } from 'vue-i18n';

const i18n = createI18n({
  legacy: false, // 如果你使用 Composition API(推薦),請將legacy設置為false
  locale: 'zh', // 默認語言環境
  messages: {
    en: {
      hello: 'Hello',
      welcome: 'Welcome to our app!',
    },
    zh: {
      hello: '你好',
      welcome: '歡迎來到我們的應用!',
    },
  },
});


createApp(App).use(i18n).use(router).use(ArcoVue,{}).use(ArcoVueIcon).mount('#app');

顯示代碼:

<p>{{ $t('welcome') }}</p>

剩余的兩個功能,下一篇再完善。預告下,后面我把這個項目的模塊進行分解,然后子模塊拆分成技術點,然后通過chatgpt來實現,看看它的效果如何。敬請期待!是否能實現大部分功能,我們拭目以待。

責任編輯:姜華 來源: 今日頭條
相關推薦

2019-11-18 14:00:40

開發工具環境搭建vagrant

2012-09-04 10:12:19

IBMdw

2024-08-13 15:50:57

2011-06-28 10:29:15

QT 桌面 程序

2015-09-02 10:26:58

主機機房

2023-06-03 00:04:43

Electron版本安全

2024-02-21 09:43:50

ElectronNode.js前端

2023-08-16 00:52:31

Electron開發工具

2023-10-11 10:03:33

Electron桌面應用開發工具

2023-12-06 09:02:56

Electron前端

2023-04-05 22:42:08

Electronsize工具

2020-02-03 09:30:42

開發技能代碼

2015-07-20 17:12:57

2020-10-13 08:00:00

公共數據集Google Tren大數據

2023-12-21 09:16:40

Electron前端多進程架構

2018-01-04 10:40:23

2022-02-25 14:00:40

IT領導者技術

2025-01-26 08:35:01

First UI移動端開發

2010-09-25 13:47:14

Java跨平臺

2024-10-15 09:59:52

點贊
收藏

51CTO技術棧公眾號

一区二区视频网站| 在线黄色免费网站| 成人福利片网站| 国产大片一区二区| 欧美怡红院视频一区二区三区| 一本色道综合久久欧美日韩精品| 日韩欧美看国产| 国产精品久久久久久久久免费桃花| 91精品一区二区| 国产 欧美 日韩 在线| 精品国产一区二区三区香蕉沈先生 | av在线免费观看网址| av在线综合网| 国产美女精品视频免费观看| 国产一级视频在线播放| 欧美综合在线视频观看 | 天堂中文字幕在线| 老司机精品导航| 欧美日韩国产成人高清视频| 国内精品卡一卡二卡三| av成人资源网| 欧美日韩免费观看一区二区三区| 国产96在线 | 亚洲| 日本蜜桃在线观看| 久久人人爽人人爽| 国产精品一区二区三区不卡| 中文在线免费观看| 国产日韩欧美| 久久久久久91| 91日韩中文字幕| 日韩理论片av| 亚洲天堂视频在线观看| 国产黑丝在线观看| 欧美激情精品| 在线播放一区二区三区| 久久精品一区二| 成入视频在线观看| 亚洲综合另类小说| 佐佐木明希av| 久久精品视频免费看| 国产女主播视频一区二区| 国内精品二区| 欧美特级特黄aaaaaa在线看| 国产精品羞羞答答xxdd| 91精品久久久久久久久久久| 黄色大全在线观看| 天堂va蜜桃一区二区三区| 91国偷自产一区二区三区的观看方式| 日韩a级片在线观看| 99re66热这里只有精品8| 亚洲人高潮女人毛茸茸| 青青草视频播放| 欧美爱爱网站| 日韩精品在线视频美女| 极品粉嫩小仙女高潮喷水久久| 99热这里只有精品首页| 精品日韩欧美在线| 成年女人免费视频| 国产精品中文字幕制服诱惑| 精品国产百合女同互慰| 免费啪视频在线观看| 911精品国产| 亚洲成人在线视频播放| 日韩少妇一区二区| 日韩欧美黄色| 国产午夜精品视频| 秋霞网一区二区三区| 欧美日韩激情| 久久夜色精品国产| 国产亚洲第一页| 99精品视频免费全部在线| 98视频在线噜噜噜国产| 中文在线第一页| 日本怡春院一区二区| 国产精品夜间视频香蕉| 国产视频在线观看免费 | 91九色蝌蚪嫩草| 成人无码一区二区三区| 99这里只有久久精品视频| 免费在线一区二区| 在线观看二区| 一区二区三区欧美亚洲| 欧美综合在线播放| 韩国精品主播一区二区在线观看| 欧美日韩免费观看一区二区三区 | 亚洲免费资源| 日韩欧美中文一区二区| 中文字幕人妻一区二区三区| 亚洲黄页在线观看| 中文字幕一区电影| 国产一级特黄a高潮片| 久久国产高清| 成人精品一区二区三区| 人妻丰满熟妇av无码区hd| 久久蜜桃一区二区| 青春草在线视频免费观看| 1区2区3区在线| 欧美体内she精视频| 午夜xxxxx| 色爱综合av| 久久久国产一区二区| 国产一区二区99| 激情久久五月天| 免费国产在线精品一区二区三区| 久热国产在线| 在线观看视频91| av在线天堂网| 不卡日本视频| 91精品国产91久久久久久最新| 亚洲综合五月天婷婷丁香| 白白色亚洲国产精品| 夜夜爽99久久国产综合精品女不卡 | 国产视频视频一区| 欧美这里只有精品| 国产情侣一区二区三区| 亚洲激情视频在线观看| 国产福利视频网站| 亚洲看片免费| 亚洲最大的免费| av在线免费观看网| 欧美日韩激情美女| www.啪啪.com| 欧美日韩网址| 成人免费自拍视频| 国产在线高清| 欧美性生活大片免费观看网址| 日本成人在线免费| 亚洲a一区二区三区| 国产精品久久久999| 天堂中文在线资| 亚洲成人av一区二区三区| 欧美性猛交乱大交| 久久久久美女| 91久久久久久| 欧美成人高清在线| 欧美三级电影一区| 色噜噜噜噜噜噜| 日韩成人一级大片| 茄子视频成人在线观看| 少妇高清精品毛片在线视频 | 亚洲人成伊人成综合网小说| 日韩福利视频在线| 久久99高清| 清纯唯美日韩制服另类| 色天堂在线视频| 欧美日韩午夜视频在线观看| 亚洲一级Av无码毛片久久精品| 2023国产精品久久久精品双| 成人福利视频在线观看| 日本中文字幕电影在线免费观看| 欧美亚洲日本国产| 日韩一区二区三区四区视频| 蜜臀a∨国产成人精品| 亚洲国产精品一区二区第一页| 日韩成人影音| 色哟哟网站入口亚洲精品| 一级片视频免费| 专区另类欧美日韩| 精品国产午夜福利在线观看| 中文字幕午夜精品一区二区三区| 超碰97在线播放| mm视频在线视频| 国产视频欧美视频| 波多野结衣电车痴汉| 国产精品色哟哟网站| 欧美成人福利在线观看| 68国产成人综合久久精品| 亚洲aⅴ男人的天堂在线观看| a视频在线播放| 精品国产免费视频| 国产又大又黄视频| 国产日本一区二区| wwwwwxxxx日本| 国产在成人精品线拍偷自揄拍| 国产成人久久精品77777最新版本| 欧美中日韩在线| 亚洲精品推荐| 国产欧美日韩91| 欧美精品videosex| 日韩经典一区二区三区| 色老头在线视频| 亚洲欧洲av在线| caopor在线| 日韩制服丝袜先锋影音| 青青草原国产免费| 国产精品17p| 国产成人一区二区三区电影| 免费在线午夜视频| 精品免费日韩av| 亚洲精品男人的天堂| 中文字幕亚洲电影| 亚洲熟女一区二区| 蜜桃精品视频在线观看| 又大又硬又爽免费视频| 欧美限制电影| 成人激情视频免费在线| 波多野一区二区| www.国产一区| 日韩电影在线观看完整版| 欧美精品在欧美一区二区少妇| 国产一级视频在线| 中文一区二区完整视频在线观看| 91精品人妻一区二区三区四区| 久久国产精品久久久久久电车 | av电影在线观看| 精品久久一二三区| 在线免费观看一区二区| 黄网站色欧美视频| 日韩在线观看视频一区二区| 国产网站一区二区| 9.1在线观看免费| 精品无人码麻豆乱码1区2区| 人妻熟女一二三区夜夜爱| 亚洲综合婷婷| 天天爽天天狠久久久| 国产精品香蕉| 亚洲一区二区三区xxx视频| 欧美大胆性生话| 午夜精品一区二区三区在线视| 免费黄色在线看| 国产亚洲精品美女久久久久| 四虎永久在线观看| 日韩免费视频一区| 一区二区三区免费在线视频| 色婷婷亚洲婷婷| 国产精品黄色大片| 午夜一区二区三区视频| 91精品国产高清一区二区三蜜臀| 国产精品每日更新| 少妇无套高潮一二三区| 99re视频精品| 国产 xxxx| 成人v精品蜜桃久久一区| 亚洲高清av一区二区三区| 捆绑调教一区二区三区| 免费裸体美女网站| 视频一区视频二区中文| 97在线播放视频| 久久九九精品| 成人一级片网站| 久久精品人人| 男人操女人免费软件| 亚洲精品乱码| 欧美一级视频免费看| 国内自拍一区| 男女私大尺度视频| 亚洲精品欧洲| 91精品91久久久中77777老牛| 亚洲作爱视频| 欧美日韩激情视频在线观看| aa级大片欧美三级| 人人妻人人添人人爽欧美一区| 99热免费精品在线观看| 国产深夜男女无套内射| 一区二区三区福利| 欧美aⅴ在线观看| 视频在线观看国产精品| 五月婷婷狠狠操| 美女性感视频久久| 911av视频| 成人性生交大片免费| 国产人妻黑人一区二区三区| www国产精品av| 日本高清黄色片| 亚洲欧美乱综合| 久久久久99精品| 欧美日韩亚洲激情| 波多野结衣二区三区| 91精品蜜臀在线一区尤物| 亚洲高清视频在线播放| 日韩久久精品电影| 在线免费看黄| 久久久久国色av免费观看性色| 在线毛片观看| 国产色视频一区| 亚洲专区**| 欧美日韩国产高清视频| 欧美a级成人淫片免费看| 日本天堂免费a| 日韩av无码中文字幕| 国产精品乱人伦| 欧美被狂躁喷白浆精品| 欧美午夜丰满在线18影院| 中文字幕1区2区3区| 日韩一区二区三区四区| 香蕉视频911| 最近免费中文字幕视频2019| 中文字幕伦理免费在线视频| 97免费在线视频| 福利一区二区三区视频在线观看| 91网免费观看| 免费看成人哺乳视频网站| 艳母动漫在线观看| 西西人体一区二区| 三级黄色片免费看| 久久五月婷婷丁香社区| 欧美爱爱免费视频| 欧美性猛交xxxx富婆弯腰| 国产精品一级视频| 亚洲女同性videos| 日本理论片午伦夜理片在线观看| 日韩av男人的天堂| h视频久久久| 亚洲三区在线观看| 午夜亚洲性色视频| 天天色天天干天天色| 国产日韩成人精品| 日韩三级一区二区三区| 欧美高清精品3d| 亚洲日本香蕉视频| 最近2019年日本中文免费字幕| 日本在线视频www鲁啊鲁| 国产精品亚发布| 欧美热在线视频精品999| 97中文字幕在线| 美女脱光内衣内裤视频久久网站 | 一区精品在线观看| 亚洲黄色www网站| av文字幕在线观看| 国产精品视频网| 综合综合综合综合综合网| 免费看毛片的网址| 国产精品一区二区果冻传媒| 国产123在线| 色系网站成人免费| 日韩一二三四| 91av在线视频观看| 久久超级碰碰| 免费一级特黄毛片| 懂色av一区二区三区蜜臀| 91在线播放观看| 宅男噜噜噜66一区二区66| 1024免费在线视频| 国产精品69av| 国产欧美一区| 国产日韩一区二区在线观看| www.亚洲色图.com| 国产福利拍拍拍| 亚洲国产精品电影在线观看| bl视频在线免费观看| 国产美女在线精品免费观看| 亚洲一级二级| 中国免费黄色片| 亚洲h在线观看| 天天爽夜夜爽夜夜爽| 国语自产精品视频在线看抢先版图片 | 国产艳妇疯狂做爰视频| 亚洲午夜久久久久久久久电影院 | 亚洲人成啪啪网站| 久久精品女人天堂av免费观看| 精品国产区在线| 免费亚洲一区| 精品无码人妻一区二区免费蜜桃| 色999日韩国产欧美一区二区| 精品久久久久一区二区三区| 日韩**中文字幕毛片| 国产欧美一区| 在线不卡一区二区三区| 亚洲欧美偷拍卡通变态| 国产欧美一级片| 久久久久久久久网站| 欧美三级午夜理伦三级小说| 色综合av综合无码综合网站| 欧美国产日本韩| 国产国语亲子伦亲子| 久久久久久尹人网香蕉| 亚洲va久久| 亚洲娇小娇小娇小| 亚洲一区在线视频| 四虎精品成人影院观看地址| 国产精品成人国产乱一区| 91精品国产视频| 中文字幕人妻一区| 色综合天天在线| 欧美成人精品一区二区男人看| 成人自拍偷拍| 美女诱惑黄网站一区| 国产中文字幕久久| 精品国产髙清在线看国产毛片| 在线天堂资源www在线污| 亚洲精品在线免费看| 国产电影一区二区三区| 影音先锋在线国产| 久热精品视频在线观看一区| 国内精品麻豆美女在线播放视频| 亚洲精品乱码久久久久久自慰| 亚洲人成7777| 日韩专区一区二区| 91夜夜揉人人捏人人添红杏| 99精品免费网| 免费三级在线观看| 精品香蕉在线观看视频一| 亚洲伊人伊成久久人综合网| 免费看黄在线看| 国产精品久久久久aaaa樱花| 成人免费一级视频| 国产久一一精品| 亚洲神马久久| 国产女人被狂躁到高潮小说| 亚洲色图25p|