python使用pywebview集成vue3和element-plus开发桌面系统框架

发布于:2024-07-05 ⋅ 阅读:(59) ⋅ 点赞:(0)

随着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 webview

from controller.IndexController import IndexController


class 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


网站公告

今日签到

点亮在社区的每一天
去签到