python使用pywebview集成vue3和element-plus開發桌面系統框架

隨著web技術越來越成熟,就連QQ的windows客戶端都用web技術來開發,所以在未來,web技術來開發windows桌面軟件也會越來越多,所以在此發展驅動之下,將最近流程的python與web技術相結合,使用vue3和element-plus、vue-router、saas(CSS擴展語言),來開發桌面管理系統,也是一個不錯的選擇。最主要的是兩者技術門檻比較低,而且開發效率也很快,同時也可以做出漂亮的界面。

一、技術背景

python:版本號為3.7(你也可以換成高版本,同樣支持)

vue3:版本為3.4.29

element-plus:版本號:element-plus

vue-router:版本號為4.4.0

sass:1.53.0

操作系統為:windows10

二、先看效果

三、web關鍵代碼-登陸頁面

<template><div class="login-container"><h1>用戶登錄</h1><form class="login-form"><div class="form-group"><label>用戶名:</label><input type="text"  /></div><div class="form-group"><label>密碼:</label><input type="password" /></div><button type="submit" @click="login">登錄</button></form></div>
</template><script setup>
import {onMounted, getCurrentInstance,ref,computed} from "vue";
import {useStore} from "vuex";
const {proxy} = getCurrentInstance();
const login = async ()=>{window.pywebview.api.login('','')
}
</script>
<style lang="scss" scoped>
.login-container {max-width: 400px;margin: 0 auto;padding: 50px 20px;box-sizing: border-box;text-align: center;
}
.login-form {width: 80%;margin: 0 auto;
}
.form-group {margin-bottom: 20px;text-align: left;
}
label {display: inline-block;width: 100px;
}
</style>

四、web關鍵代碼-首頁

<template><el-table :data="tableData" style="width: 100%"><el-table-column prop="date" label="Date" width="180" /><el-table-column prop="name" label="Name" width="180" /><el-table-column prop="address" label="Address" /></el-table>
</template><script setup>import {onMounted, getCurrentInstance,ref,computed} from "vue";import {useStore} from "vuex";const {proxy} = getCurrentInstance();const tableData = [{date: '2016-05-03',name: 'Tom',address: 'No. 189, Grove St, Los Angeles',},{date: '2016-05-02',name: 'Tom',address: 'No. 189, Grove St, Los Angeles',},{date: '2016-05-04',name: 'Tom',address: 'No. 189, Grove St, Los Angeles',},{date: '2016-05-01',name: 'Tom',address: 'No. 189, Grove St, Los Angeles',},]
</script>
<style lang="scss" scoped></style>

五、pywebview關鍵代碼

import webviewfrom controller.IndexController import IndexControllerclass Api():def destroy(self):window.destroy()def minimize(self):window.minimize()def login(self, username, password):print(username, '  ', password)main = IndexController(username)main.start()self.destroy()if __name__ == '__main__':api = Api()# js_api 獲得 api 實例window = webview.create_window('登錄', 'http://localhost:3004/#/login', js_api=api, resizable=False, width=450,  frameless=False, shadow=True, height =670, background_color="#E4FBF0")webview.start()# webview.start(debug=True)

六、拿到代碼執行如下命令

1、前端(必須先安裝nodejs,百度自行先安裝),進入到pywebview-desktop-app\web目錄,執行如下命令,下載依賴

npm install

2、運行前端(在目錄pywebview-desktop-app\web下),執行如下命令

npm run dev

3、啟動python客戶端,在pywebview-desktop-app\controller目錄,運行LoginController.py文件

七、效果圖如下

下載地址:鏈接:https://pan.baidu.com/s/1TH_UQx7sblW6O_6K6ZPqlA?pwd=thfk?
提取碼:thfk

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/40216.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/40216.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/40216.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

圖像增強 目標檢測 仿射變換 圖像處理 扭曲圖像

1.背景 在目標檢測中&#xff0c;需要進行圖像增強。這里的代碼模擬了旋轉、扭曲圖像的功能&#xff0c;并且在扭曲的時候&#xff0c;能夠同時把標注的結果也進行扭曲。 這里忽略了讀取xml的過程&#xff0c;假設圖像IMG存在對應的標注框&#xff0c;且坐標為左上、右下兩個…

[C++初階]vector的初步理解

一、標準庫中的vector類 1.vector的介紹 1. vector是表示可變大小數組的序列容器 &#xff0c; 和數組一樣&#xff0c;vector可采用的連續存儲空間來存儲元素。也就是意味著可以采用下標對vector的元素進行訪問&#xff0c;和數組一樣高效。但是又不像數組&#xff0c;它的大…

災后恢復與勒索恢復的區別

災難恢復通常側重于物理基礎設施&#xff0c;如硬盤和網絡設備&#xff0c;而勒索軟件恢復則涉及數據完整性和防范網絡威脅。 BackBox 產品管理副總裁 Amar Ramakrishnan表示&#xff0c;在災難中&#xff0c;企業可能面臨硬件受損等問題&#xff0c;但在網絡安全事件中&#…

Java學習高級一

修飾符 static 類變量的應用場景 成員方法的分類 成員變量的執行原理 成員方法的執行原理 Java之 main 方法 類方法的常見應用場景 代碼塊 設計模式 單例設計模式 餓漢式單例設計模式 懶漢式單例設計模式 繼承 權限修飾符

小紅書 達芬奇:生活問答 AI 機器人

小紅書去年 9 月開始內測的生活問答 AI 機器人&#xff1a;達芬奇&#xff0c;現在可以在小紅書 APP 上用了 得益于小紅書平臺的特性&#xff0c;該助手擅長吃、住、寵、喝、學等等各類生活知識&#xff0c;目前還在搞活動&#xff0c;寫評測筆記最高得 666 元

為什么不能在foreach中刪除元素

文章目錄 快速失敗機制&#xff08;fail-fast&#xff09;for-each刪除元素為什么報錯原因分析邏輯分析 如何正確的刪除元素remove 后 breakfor 循環使用 Iterator 總結 快速失敗機制&#xff08;fail-fast&#xff09; In systems design, a fail-fast system is one which i…

合肥高新區建設世界領先科技園區政策(商務部分)申報獎勵補貼和條件材料、時間指南

一、合肥高新區建設世界領先科技園區政策&#xff08;商務部分&#xff09;申報主體 &#xff08;更多政策可以查看小編主頁方式&#xff09; 工商、稅務、統計關系均在合肥高新區&#xff0c;并在高新區持續經營。申請項目在高新區內實施、且符合政策要求的具有獨立法人資格…

網絡基礎:EIGRP

EIGRP&#xff08;Enhanced Interior Gateway Routing Protocol&#xff09;是由思科開發的一種高級距離矢量路由協議&#xff0c;結合了距離矢量和鏈路狀態路由協議的優點&#xff1b;EIGRP具有快速收斂、高效帶寬利用、負載均衡等特點&#xff0c;適用于各種規模的網絡。EIGR…

python sklearn機械學習-數據預處理

&#x1f308;所屬專欄&#xff1a;【機械學習】?作者主頁&#xff1a; Mr.Zwq??個人簡介&#xff1a;一個正在努力學技術的Python領域創作者&#xff0c;擅長爬蟲&#xff0c;逆向&#xff0c;全棧方向&#xff0c;專注基礎和實戰分享&#xff0c;歡迎咨詢&#xff01; 您…

【設計模式】策略模式(定義 | 特點 | Demo入門講解)

文章目錄 定義策略模式的結構 QuickStart | DemoStep1 | 策略接口Step2 | 策略實現Step3 | 上下文服務類Step4 | 客戶端 策略模式的特點優點缺點 定義 策略模式Strategy是一種行為模式&#xff0c;它能定義一系列算法&#xff0c;并將每種算法分別放入到獨立的類中&#xff0c…

書籍表達式得到期望結果的組成種數

題目 給定一個只由0(假)、1(真)、&(邏輯與)、|(邏輯或)和^(異或)五種組成的字符串express&#xff0c;再給定一個布爾值desired。返回express能有多少種組合方式。可以達到desired的結果。 舉例 express“1^0|0|1”,desiredfalse. 只有1^((0|0)|1)和1^(0|(0|1))的組合可…

負載均衡類型和算法解析

假如你正在設計和開發一個分布式服務系統&#xff0c;系統中存在一批能夠獨立運行的服務&#xff0c;而在部署上也采用了集群模式以防止出現單點故障。所謂集群&#xff0c;就是指將多個服務實例集中在一起&#xff0c;對外提供同一業務功能&#xff0c;也就是任意請求都可以由…

吉利銀河L6 AQS空氣質量監控系統

結論 頂配才有AQS 開啟空調且auto模式 則默認開啟AQS 無法關閉AQS AQS的作用 銀河L6 AQS觸發 和 圖標 AQS官方配置參數 官方文檔 吉利用戶手冊

開源即正義,3D軟件Blender設計指南

在當今數字化時代&#xff0c;開源軟件的崛起不僅代表著技術的發展&#xff0c;更象征著一種信息自由和技術民主的理念。其本質是集眾人之智&#xff0c;共同去完善一個軟件&#xff0c;最終使雙方互惠共贏。具體來說&#xff0c;開源的價值&#xff0c;在于打破資源壟斷&#…

Spring的事務管理、AOP實現底層

目錄 spring的事務管理是如何實現的&#xff1f; Spring的AOP的底層實現原理 spring的事務管理是如何實現的&#xff1f; 首先&#xff0c;spring的事務是由aop來實現的&#xff0c;首先要生成具體的代理對象&#xff0c;然后按照aop的整套流程來執行具體的操作邏輯&#xf…

NLP - 基于bert預訓練模型的文本多分類示例

項目說明 項目名稱 基于DistilBERT的標題多分類任務 項目概述 本項目旨在使用DistilBERT模型對給定的標題文本進行多分類任務。項目包括從數據處理、模型訓練、模型評估到最終的API部署。該項目采用模塊化設計&#xff0c;以便于理解和維護。 項目結構 . ├── bert_dat…

蘋果AI的國產大模型之爭,沒有懸念

文 | 智能相對論 作者 | 陳泊丞 蘋果終于公布了最新的AI進程。 一個月前&#xff0c;正如此前預期的那樣&#xff0c;人工智能是今年 WWDC 發布會的焦點。全程105分鐘的主題演講&#xff0c;就有40多分鐘用于介紹蘋果的AI成果。 蘋果似乎還有意玩了一把“諧音梗”&#xff…

用機器改變人類方向

1800 世紀初&#xff0c;美國迎來了工業革命&#xff0c;這是一個由技術進步推動的變革時代。新機器和制造技術的引入重塑了經濟格局&#xff0c;提高了生產效率&#xff0c;同時減少了某些領域對手工勞動的需求。因此&#xff0c;這種轉變導致了失業。 如今&#xff0c;我們看…

實現點擊按鈕導出頁面pdf

在Vue 3 Vite項目中&#xff0c;你可以使用html2canvas和jspdf庫來實現將頁面某部分導出為PDF文檔的功能。以下是一個簡單的實現方式&#xff1a; 1.安裝html2canvas和jspdf&#xff1a; pnpm install html2canvas jspdf 2.在Vue組件中使用這些庫來實現導出功能&#xff1a;…

統計信號處理基礎 習題解答11-11

題目 考慮矢量MAP估計量 證明這個估計量對于代價函數 使貝葉斯風險最小。其中&#xff1a;, &#xff0c;且. 解答 貝葉斯風險函數&#xff1a; 基于概率密度的非負特性&#xff0c;上述對積分要求最小&#xff0c;那就需要內層積分達到最小。令內層積分為&#xff1a; 上述積…