{"id":16992,"date":"2024-02-26T15:43:19","date_gmt":"2024-02-26T07:43:19","guid":{"rendered":"https:\/\/www.zhidianwl.net\/zhidianwl\/?p=16992"},"modified":"2024-02-26T15:43:19","modified_gmt":"2024-02-26T07:43:19","slug":"vue%e8%83%bd%e6%89%93%e5%8c%85exe%e5%90%97","status":"publish","type":"post","link":"https:\/\/www.zhidianwl.net\/zhidianwl\/2024\/02\/26\/vue%e8%83%bd%e6%89%93%e5%8c%85exe%e5%90%97\/","title":{"rendered":"vue\u80fd\u6253\u5305exe\u5417?"},"content":{"rendered":"

Vue.js \u662f\u4e00\u6b3e\u975e\u5e38\u6d41\u884c\u7684 JavaScript \u524d\u7aef\u6846\u67b6\uff0c\u5b83\u53ef\u4ee5\u7528\u4e8e\u5feb\u901f\u5f00\u53d1\u5355\u9875\u5e94\u7528\u7a0b\u5e8f\uff08SPA\uff09\u3002\u867d\u7136 Vue.js \u5728\u5f00\u53d1 Web \u5e94\u7528\u7a0b\u5e8f\u65b9\u9762\u975e\u5e38\u5f3a\u5927\u548c\u7075\u6d3b\uff0c\u4f46\u662f\u5b83\u5e76\u4e0d\u80fd\u76f4\u63a5\u5c06\u722c\u866b\u6253\u5305exe<\/a>\u5e94\u7528\u7a0b\u5e8f\u6253\u5305\u6210\u53ef\u6267\u884c\u6587\u4ef6\uff08.exe\uff09\u3002<\/p>\n

\u5728\u5c06 Vue.js \u5e94\u7528\u7a0b\u5e8f\u6253\u5305\u6210\u53ef\u6267\u884c\u6587\u4ef6\u4e4b\u524d\uff0c\u9700\u8981\u5148\u5c06\u5176\u8f6c\u6362\u4e3a\u53ef\u6267\u884c\u6587\u4ef6\u683c\u5f0f\u3002\u8fd9\u53ef\u4ee5\u901a\u8fc7\u4f7f\u7528 Electron \u6846\u67b6\u6765\u5b9e\u73b0\u3002Electron \u662f\u4e00\u4e2a\u7528\u4e8e\u6784\u5efa\u8de8\u5e73\u53f0\u684c\u9762\u5e94\u7528\u7a0b\u5e8f\u7684\u5f00\u6e90\u6846\u67b6\uff0c\u5b83\u53ef\u4ee5\u5c06 Web \u6280\u672f\uff08\u5982 HTML\u3001CSS \u548c JavaScript\uff09\u6253\u5305\u6210\u53ef\u6267\u884c\u6587\u4ef6\u3002<\/p>\n

\u4e0b\u9762\u662f\u4f7f\u7528 Electron \u6846\u67b6\u5c06 Vue.js \u5e94\u7528\u7a0b\u5e8f\u6253\u5305\u6210\u53ef\u6267\u884c\u6587\u4ef6\u7684\u6b65\u9aa4\uff1a<\/p>\n

1. \u5b89\u88c5 Electron<\/p>\n

\u9996\u5148\uff0c\u9700\u8981\u5b89\u88c5 Electron\u3002\u53ef\u4ee5\u4f7f\u7528 npm \u547d\u4ee4\u6765\u5b89\u88c5 Electron\uff1a<\/p>\n

“`<\/p>\n

npm install electron –save-dev<\/p>\n

“`<\/p>\n

2. \u521b\u5efa Electron \u5e94\u7528\u7a0b\u5e8f<\/p>\n

\u63a5\u4e0b\u6765\uff0c\u9700\u8981\u521b\u5efa\u4e00\u4e2a\u65b0\u7684 Electron \u5e94\u7528\u7a0b\u5e8f\u3002\u53ef\u4ee5\u4f7f\u7528 Electron Quick Start \u6a21\u677f\u6765\u521b\u5efa\u4e00\u4e2a\u65b0\u7684 Electron \u5e94\u7528\u7a0b\u5e8f\u3002\u5728\u547d\u4ee4\u884c\u4e2d\u6267\u884c\u4ee5\u4e0b\u547d\u4ee4\uff1a<\/p>\n

“`<\/p>\n

git clone https:\/\/github.com\/electron\/electron-quick-start<\/p>\n

cd electron-quick-start<\/p>\n

npm install<\/p>\n

“`<\/p>\n

3. \u5c06 Vue.js \u5e94\u7528\u7a0b\u5e8f\u6dfb\u52a0\u5230 Electron \u5e94\u7528\u7a0b\u5e8f\u4e2d<\/p>\n

\u5c06 Vue.js \u5e94\u7528\u7a0b\u5e8f\u6dfb\u52a0\u5230 Electron \u5e94\u7528\u7a0b\u5e8f\u4e2d\u9700\u8981\u8fdb\u884c\u4e00\u4e9b\u4fee\u6539\u3002\u9996\u5148\uff0c\u9700\u8981\u5c06 Vue.js \u5e94\u7528\u7a0b\u5e8f\u7684\u4ee3\u7801\u590d\u5236\u5230 Electron \u5e94\u7528\u7a0b\u5e8f\u7684\u201crenderer\u201d\u6587\u4ef6\u5939\u4e2d\u3002\u7136\u540e\uff0c\u5728 Electron \u5e94\u7528\u7a0b\u5e8f\u7684\u201cmain.js\u201d\u6587\u4ef6\u4e2d\u6dfb\u52a0\u4ee5\u4e0b\u4ee3\u7801\uff1a<\/p>\n

“`<\/p>\n

const { app, BrowserWindow } = require(‘electron’)<\/p>\n

funct\u591a\u4e2aexe\u6253\u5305\u4e3a\u4e00\u4e2aexe\u8f6f\u4ef6\u5de5\u5177<\/a>ion createWindow () {<\/p>\n

\/\/ \u521b\u5efa\u6d4f\u89c8\u5668\u7a97\u53e3<\/p>\n

let win = new BrowserWindow({<\/p>\n

width: 800,<\/p>\n

height: 600,<\/p>\n

webPreferences: {<\/p>\n

nodeIntegration: true<\/p>\n

}<\/p>\n

})<\/p>\n

\/\/ \u52a0\u8f7d Vue.js \u5e94\u7528\u7a0b\u5e8f<\/p>\n

win.loadFile(‘renderer\/index.html’)<\/p>\n

}<\/p>\n

app.on(‘ready’, createWindow)<\/p>\n

“`<\/p>\n

\u8fd9\u6bb5\u4ee3\u7801\u5c06\u521b\u5efa\u4e00\u4e2a\u65b0\u7684\u6d4f\u89c8\u5668\u7a97\u53e3\uff0c\u5e76\u52a0\u8f7d Vue.js \u5e94\u7528\u7a0b\u5e8f\u7684\u201cindex.html\u201d\u6587\u4ef6\u3002<\/p>\n

4. \u6253\u5305 Electron \u5e94\u7528\u7a0b\u5e8f<\/p>\n

\u5b8c\u6210\u4e86\u4ee5\u4e0a\u6b65\u9aa4\u540e\uff0c\u5c31\u53ef\u4ee5\u5c06 Electron \u5e94\u7528\u7a0b\u5e8f\u6253\u5305\u6210\u53ef\u6267\u884c\u6587\u4ef6\u4e86\u3002\u53ef\u4ee5\u4f7f\u7528 Electron Builder \u5de5\u5177\u6765\u6253\u5305 Electron \u5e94\u7528\u7a0b\u5e8f\u3002\u5728\u547d\u4ee4\u884c\u4e2d\u6267\u884c\u4ee5\u4e0b\u547d\u4ee4\u6765\u5b89\u88c5 Electron Builder\uff1a<\/p>\n

“`<\/p>\n

npm install electron-builder –save-dev<\/p>\n

“`<\/p>\n

\u7136\u540e\uff0c\u5728 Electron \u5e94\u7528\u7a0b\u5e8f\u7684\u201cpackage.json\u201d\u6587\u4ef6\u4e2d\u6dfb\u52a0\u4ee5\u4e0b\u4ee3\u7801\uff1a<\/p>\n

“`<\/p>\n

“build”: {<\/p>\n

“appId”: “com.example.app”,<\/p>\n

“productName”: “My App”,<\/p>\n

“directories”: {<\/p>\n

“output”: “dist”<\/p>\n

},<\/p>\n

“files”: [<\/p>\n

“main.js”,<\/p>\n

“renderer\/**\/*”<\/p>\n

],<\/p>\n

“dmg”: {<\/p>\n

“contents”: [<\/p>\n

{<\/p>\n

“x”: 410,<\/p>\n

“y”: 150,<\/p>\n

“type”: “link”,<\/p>\n

“path”: “\/Applications”<\/p>\n

},<\/p>\n

{<\/p>\n

“x”: 130,<\/p>\n

“y”: 150,<\/p>\n

“type”: “file”<\/p>\n

}<\/p>\n

]<\/p>\n

},<\/p>\n

“win”: {<\/p>\n

\n

<\/figure>\n<\/p>\n

“target”: “nsis”,<\/p>\n

“icon”: “build\/icon.ico”<\/p>\n

}<\/p>\n

}<\/p>\n

“`<\/p>\n

\u8fd9\u6bb5\u4ee3\u7801\u5c06\u544a\u8bc9 Electron Builder \u5982\u4f55\u6253\u5305 Electron \u5e94\u7528\u7a0b\u5e8f\u3002\u5728\u547d\u4ee4\u884c\u4e2d\u6267\u884c\u4ee5\u4e0b\u547d\u4ee4\u6765\u6253\u5305 Electron \u5e94\u7528\u7a0b\u5e8f\uff1a<\/p>\n

“`<\/p>\n

npm run dist<\/p>\n

“`<\/p>\n

\u6253\u5305\u5b8c\u6210\u540e\uff0c\u4f1a\u5728\u201cdist\u201d\u6587\u4ef6\u5939\u4e2d\u751f\u6210\u53ef\u6267\u884c\u6587\u4ef6\u3002<\/p>\n

\u603b\u7ed3<\/p>\n

\u5728\u5c06 Vue.js \u5e94\u7528\u7a0b\u5e8f\u6253\u5305\u6210\u53ef\u6267\u884c\u6587\u4ef6\u4e4b\u524d\uff0c\u9700\u8981\u5148\u5c06\u5176\u8f6c\u6362\u4e3a\u53ef\u6267\u884c\u6587\u4ef6\u683c\u5f0f\u3002\u8fd9\u53ef\u4ee5\u901a\u8fc7\u4f7f\u7528 Electron \u6846\u67b6\u6765\u5b9e\u73b0\u3002\u867d\u7136\u8fd9\u4e2a\u8fc7\u7a0b\u53ef\u80fd\u6bd4\u8f83\u590d\u6742\uff0c\u4f46\u662f\u5b83\u53ef\u4ee5\u8ba9\u4f60\u7684 Vue.js \u5e94\u7528\u7a0b\u5e8f\u5728\u684c\u9762\u4e0a\u8fd0\u884c\uff0c\u5e76\u4e14\u53ef\u4ee5\u65b9\u4fbf\u5730\u5206\u4eab\u7ed9\u5176\u4ed6\u4eba\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"

Vue.js \u662f\u4e00\u6b3e\u975e\u5e38\u6d41\u884c\u7684 JavaScript \u524d\u7aef\u6846\u67b6\uff0c\u5b83\u53ef\u4ee5\u7528\u4e8e\u5feb\u901f\u5f00\u53d1\u5355\u9875\u5e94\u7528\u7a0b\u5e8f\uff08SPA\uff09\u3002\u867d\u7136 Vue.js \u5728\u5f00\u53d1 Web \u5e94\u7528\u7a0b\u5e8f\u65b9\u9762\u975e\u5e38\u5f3a\u5927\u548c\u7075\u6d3b\uff0c\u4f46\u662f\u5b83\u5e76\u4e0d\u80fd\u76f4\u63a5\u5c06\u5e94\u7528\u7a0b\u5e8f\u6253<\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[3],"tags":[4294,24,20006,116,268],"topic":[],"class_list":["post-16992","post","type-post","status-publish","format-standard","hentry","category-zhuomianruanjian","tag-yyzexe","tag-24","tag-exe","tag-116","tag-268"],"_links":{"self":[{"href":"https:\/\/www.zhidianwl.net\/zhidianwl\/wp-json\/wp\/v2\/posts\/16992","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.zhidianwl.net\/zhidianwl\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.zhidianwl.net\/zhidianwl\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.zhidianwl.net\/zhidianwl\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/www.zhidianwl.net\/zhidianwl\/wp-json\/wp\/v2\/comments?post=16992"}],"version-history":[{"count":1,"href":"https:\/\/www.zhidianwl.net\/zhidianwl\/wp-json\/wp\/v2\/posts\/16992\/revisions"}],"predecessor-version":[{"id":17052,"href":"https:\/\/www.zhidianwl.net\/zhidianwl\/wp-json\/wp\/v2\/posts\/16992\/revisions\/17052"}],"wp:attachment":[{"href":"https:\/\/www.zhidianwl.net\/zhidianwl\/wp-json\/wp\/v2\/media?parent=16992"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.zhidianwl.net\/zhidianwl\/wp-json\/wp\/v2\/categories?post=16992"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.zhidianwl.net\/zhidianwl\/wp-json\/wp\/v2\/tags?post=16992"},{"taxonomy":"topic","embeddable":true,"href":"https:\/\/www.zhidianwl.net\/zhidianwl\/wp-json\/wp\/v2\/topic?post=16992"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}