欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue3+electron12+dll開發(fā)客戶端配置詳解

 更新時(shí)間:2021年06月10日 15:49:05   作者:非思不可  
本文將結(jié)合實(shí)例代碼,介紹vue3+electron12+dll客戶端配置,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

當(dāng)前使用的版本為 @vue/cli4 創(chuàng)建的 vue3.0 + typescript + electron 12 版本創(chuàng)建,其他版本暫未測(cè)試。網(wǎng)上資料良莠不齊,因此花費(fèi)時(shí)間依次試驗(yàn),達(dá)到一個(gè)目前最優(yōu)解。

修改倉(cāng)庫(kù)源

由于electron版本的未知性,可能存在serve可用而build之后打開白屏的情況,因此需要謹(jǐn)慎對(duì)待。最好在版本可用的情況下commit一個(gè)版本,方便代碼回滾,如果誰(shuí)有更好的資料希望共享。

在開始配置前,可以將yarn和npm的rc文件稍作修改,使用命令或者文件直接修改.npmrc或者.yarnrc,這兩個(gè)全局配置文件一般在C:\user\你的當(dāng)前賬戶這個(gè)文件夾下,或者在當(dāng)前項(xiàng)目下新建文件命令rc文件以局部更改配置。
因?yàn)閑lectron下載會(huì)因?yàn)榫W(wǎng)絡(luò)問題而失敗,因此修改為淘寶源,華為源亦可。

npm set config registry http://registry.npm.taobao.org/
npm set config chromedriver_cdnurl http://registry.npm.taobao.org/chromedriver
npm set config electron_mirror http://registry.npm.taobao.org/electron/
npm set config electron_builder_binaries_mirror http://registry.npm.taobao.org/electron-builder-binaries/

安裝過程使用 vue create <your projectname> 自選為vue3版本,內(nèi)容創(chuàng)建后進(jìn)入項(xiàng)目目錄,追加 vue electron-builder 配置electron,版本選擇當(dāng)前12版本。

啟動(dòng)

在package.json中已經(jīng)裝配好對(duì)應(yīng)的啟動(dòng)命令,

  • 使用npm run electron:serve 開啟開發(fā)
  • npm run electron:build 編譯打包生產(chǎn)

更換vue-devtools

項(xiàng)目工程下 src/background.ts 為electron的啟動(dòng)目錄,開發(fā)環(huán)境下會(huì)出現(xiàn)啟動(dòng)等待時(shí)間較長(zhǎng)的以下情況

Launching Electron...
Failed to fetch extension, trying 4 more times
Failed to fetch extension, trying 3 more times
Failed to fetch extension, trying 2 more times
Failed to fetch extension, trying 1 more times

是因?yàn)轫?xiàng)目需要聯(lián)網(wǎng)谷歌商店下載并加載vue-devtools失敗導(dǎo)致。

嘗試了很多辦法加載tools均失效,因此暫行手段:去掉tools。代碼找到,去掉 installExtension 即可

app.on('ready', async () => {
  if (isDevelopment && !process.env.IS_TEST) {
    // Install Vue Devtools
    try {
    //  await installExtension(VUEJS_DEVTOOLS)
    } catch (e) {
      console.error('Vue Devtools failed to install:', e.toString())
    }
  }
  createWindow()
})

之前試了很多辦法,不可用。后來(lái)再仔細(xì)對(duì)照以下,發(fā)現(xiàn)了一些問題。

vue3的版本和vue2版本的vue-devtools已然不同,所以vue2的dev-tools并不能給vue3使用,因此,需要下載vue3對(duì)應(yīng)的開發(fā)工具。vue2版本最新為5.x,而vue3的版本則為6.x beta版本。可以通過crx4chrome下載此版本的插件。將下載好的crx解壓出來(lái),然后拷貝到工程根目錄下 采用session加載的形式,將原來(lái) await installExtension(VUEJS_DEVTOOLS)的部分替換為

import {session} from 'electron'

app.on('ready', async () => {
  if (isDevelopment && !process.env.IS_TEST) {
    // Install Vue Devtools
    try {
    const vue_devtools = 'ljjemllljcmogpfapbkkighbhhppjdbg-6.0.0-beta-13-Crx4Chrome.com'
    await session.defaultSession.loadExtension(path.resolve(vue_devtools))
    } catch (e) {
      console.error('Vue Devtools failed to install:', e.toString())
    }
  }
  createWindow()
})

啟動(dòng)項(xiàng)目后,即可以查看 vue 的擴(kuò)展。 對(duì)于

(node:5904) ExtensionLoadWarning: Warnings loading extension at E:\scan\vue3_electron\ljjemllljcmogpfapbkkighbhhppjdbg-6.0.0-beta-13-Crx4Chrome.com:
  Unrecognized manifest key 'browser_action'.
  Unrecognized manifest key 'update_url'.
  Permission 'contextMenus' is unknown or URL pattern is malformed.
  Cannot load extension with file or directory name _metadata. Filenames starting with "_" are reserved for use by the system.
(Use `electron --trace-warnings ...` to show where the warning was created)

可以不予理會(huì)。如果不想看到煩人的提示可以到tools的manifest.json中刪掉提示對(duì)應(yīng)的內(nèi)容

注意事項(xiàng)

<script setup> 語(yǔ)法不可以使用

當(dāng)使用script-setup作為模塊時(shí),在serve階段可以正常使用,但是在build之后組件未加載,頁(yè)面呈現(xiàn)空白,且不報(bào)錯(cuò),原因未知

使用 electron-edge-js 加載 c# 開發(fā)的 dll 文件,配置過程略微繁瑣,花費(fèi)2天時(shí)間尋求解答,但是均未果,以下是解決辦法,需要對(duì)癥下藥

c++和c#開發(fā)的dll使用不同的加載器,c++使用ffi-napi。

使用edge需要同時(shí)增加三處配置

當(dāng)什么都沒有配置時(shí),將會(huì)發(fā)生 Uncaught (in promise) Error: Cannot find module '...\node_modules\electron\dist\resources\electron.asar\renderer\native\win32\x64\14.16.0\edge_nativeclr' 此時(shí)需要在vue.config.js文件增加,如果沒有配置文件,則需要在package.json同級(jí)創(chuàng)建。

module.exports = {
    pluginOptions: {
        electronBuilder: {
            externals: ['electron-edge-js']
        }
    }
}

當(dāng)配置未開啟時(shí),將不能使用 __dirname __filename等nodejs內(nèi)置變量
Uncaught (in promise) ReferenceError: __dirname is not defined 首先需要配置 new BrowserWindow

{      
    // 如果使用到nodejs的api,則打包時(shí)需要將此設(shè)置為true
    nodeIntegration: true,
    // 同時(shí),需要設(shè)置此項(xiàng)為false
    // 未設(shè)置時(shí)報(bào) Uncaught ReferenceError: require is not defined
    contextIsolation: false  
}

以上配置完成后會(huì)報(bào) Uncaught (in promise) TypeError: fs.existsSync is not a function
此時(shí)需要繼續(xù)增加 vue.config.js 的配置項(xiàng)

module.exports = {
    pluginOptions: {
        electronBuilder: {
            externals: ['electron-edge-js'],
            // 此處同樣需要開啟,將會(huì)在編譯階段將引用關(guān)系寫入
            nodeIntegration: true, 
        }
    }
}

如果單獨(dú)配置此項(xiàng),但是并沒有開啟 new BrowserWindow的 nodeIntegration: true ,則會(huì)發(fā)生 Uncaught ReferenceError: require is not defined

此外,對(duì)于dll放置的文件夾,一般在項(xiàng)目根目錄創(chuàng)resources用于存放資源,并且項(xiàng)目打包過程中會(huì)不會(huì)直接打包資源目錄,所以需要增加資源配置,以防止出錯(cuò)。對(duì)于文件的引用,在開發(fā)環(huán)境下,為當(dāng)前所看到的結(jié)構(gòu),當(dāng)編譯打包后,為安裝目錄下resources目錄,所以生產(chǎn)和開發(fā)的引用文件存在一定區(qū)別,可以實(shí)驗(yàn)后再看文件引用

 module.exports = {
     pluginOptions: {
         electronBuilder: {
             externals: ['electron-edge-js'],
             // 此處同樣需要開啟,將會(huì)在編譯階段將引用關(guān)系寫入
             nodeIntegration: true, 
             builderOptions:{
                 extraResources: {
                     // 拷貝靜態(tài)文件到指定位置,否則會(huì)提示文件找不到
                     from: 'resources/',
                     to: './'
                 },
             }
         }
     }
 }

提供文件獲取目錄方法,可以直接獲取不同操作系統(tǒng)下app的resource目錄,如果是window即 process.platform==='win32'

const path = require('path')
export function getAppResourcePath (filePath:string) {
    if (process.platform === 'darwin' || process.platform === 'linux') {
        if (process.env.NODE_ENV === 'development') {
            return path.resolve('resources/' + filePath)
        } else {
            return path.join(__dirname, '..') + filePath
        }
    } else {
        return path.resolve('resources/' + filePath)
    }
}

使用setup語(yǔ)法時(shí),需使用require('electron-edge-js')引入,不可以使用import,否則會(huì)報(bào) Syntax Error: TypeError: Cannot read property 'content' of null 而非 setup語(yǔ)法,則可以直接import

無(wú)邊框窗口

系統(tǒng)本身是帶有框架的,如果需要自定義框架,可以使用frameless 設(shè)置,如果需要使用自定義組件(比如 div.custom-frame-title)拖拽操作窗口時(shí),需要給對(duì)應(yīng)的元素增加樣式:

 .custom-frame-title {
   -webkit-user-select: none; // 此項(xiàng)防止與文本選擇沖突
   -webkit-app-region: drag; // 此項(xiàng)為系統(tǒng)相應(yīng)狀態(tài)欄
 }

前后臺(tái)通知

import {ipcMain,ipcRenderer} from 'electron'

在electron中有很多可用api,其中最重要的是:ipcMain和ipcRenderer,用于ui進(jìn)程和系統(tǒng)進(jìn)程的通信。 在vue內(nèi)使用ipcRenderer.on('eventname') 接受系統(tǒng)發(fā)來(lái)的消息,用ipcRenderer.send('eventname') 發(fā)送通知給系統(tǒng),同樣ipcMain可以在主線程使用。

ipc通常結(jié)合自定義標(biāo)題欄完成以下操作,或者其他需要操作窗口本身的事件

win.minimize() //最小化窗口
win.maximize() //最大化窗口
win.close() //關(guān)閉窗口
win.hide() //隱藏窗口

寫在最后

其他方式就和常規(guī)的vue開發(fā)無(wú)異,關(guān)于系統(tǒng)和ui的交互需要多翻閱api文檔 文檔地址

到此這篇關(guān)于vue3+electron12+dll開發(fā)客戶端配置詳解的文章就介紹到這了,更多相關(guān)vue3+electron12+dll客戶端配置內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue實(shí)現(xiàn)購(gòu)物車拋物線小球動(dòng)畫效果的方法詳解

    vue實(shí)現(xiàn)購(gòu)物車拋物線小球動(dòng)畫效果的方法詳解

    這篇文章主要介紹了vue實(shí)現(xiàn)購(gòu)物車拋物線小球動(dòng)畫效果的方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了vue.js實(shí)現(xiàn)拋物線動(dòng)畫效果購(gòu)物車功能相關(guān)原理與操作注意事項(xiàng),需要的朋友可以參考下
    2019-02-02
  • vue+axios?methods方法return取不到值問題及解決

    vue+axios?methods方法return取不到值問題及解決

    這篇文章主要介紹了vue+axios?methods方法return取不到值問題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • vite中使用@配置路徑別名過程示例

    vite中使用@配置路徑別名過程示例

    這篇文章主要為大家介紹了vite中使用@配置路徑別名過程示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • vue使用JSON編輯器:vue-json-editor詳解

    vue使用JSON編輯器:vue-json-editor詳解

    文章介紹了如何在Vue項(xiàng)目中使用JSON編輯器插件`vue-json-editor`,包括安裝、引入、注冊(cè)和使用示例,通過這些步驟,用戶可以在Vue應(yīng)用中輕松實(shí)現(xiàn)JSON數(shù)據(jù)的編輯功能,文章最后呼吁大家支持腳本之家
    2025-01-01
  • 在使用vuex的時(shí)候出現(xiàn)commit未定義錯(cuò)誤的解決

    在使用vuex的時(shí)候出現(xiàn)commit未定義錯(cuò)誤的解決

    這篇文章主要介紹了在使用vuex的時(shí)候出現(xiàn)commit未定義錯(cuò)誤的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • vue?動(dòng)態(tài)style?拼接寬度問題

    vue?動(dòng)態(tài)style?拼接寬度問題

    這篇文章主要介紹了vue?動(dòng)態(tài)style?拼接寬度問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue 路由子組件created和mounted不起作用的解決方法

    vue 路由子組件created和mounted不起作用的解決方法

    今天小編就為大家分享一篇vue 路由子組件created和mounted不起作用的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧
    2019-11-11
  • 圖文詳解keep-alive如何清除緩存

    圖文詳解keep-alive如何清除緩存

    vue項(xiàng)目中常常會(huì)用到keepalive來(lái)作緩存,在應(yīng)付基本要求上能夠說(shuō)很是方便,可是遇到同一個(gè)頁(yè)面,根據(jù)條件不一樣,分別緩存或者不緩存,就有些麻煩了,這篇文章主要給大家介紹了關(guān)于keep-alive如何清除緩存的相關(guān)資料,需要的朋友可以參考下
    2021-08-08
  • Vue?click事件傳遞參數(shù)的示例教程

    Vue?click事件傳遞參數(shù)的示例教程

    這篇文章主要介紹了Vue?click事件傳遞參數(shù)--方法/教程/實(shí)例,本文用示例介紹Vue中事件傳參的方法,采用click這個(gè)事件進(jìn)行展示,結(jié)合示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-12-12
  • VUE項(xiàng)目啟動(dòng)沒有問題但代碼中script標(biāo)簽有藍(lán)色波浪線標(biāo)注

    VUE項(xiàng)目啟動(dòng)沒有問題但代碼中script標(biāo)簽有藍(lán)色波浪線標(biāo)注

    這篇文章主要給大家介紹了關(guān)于VUE項(xiàng)目啟動(dòng)沒有問題但代碼中script標(biāo)簽有藍(lán)色波浪線標(biāo)注的相關(guān)資料,文中將遇到的問題以及解決的方法介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05

最新評(píng)論