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 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

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-10 22:06:06       52 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-10 22:06:06       54 阅读
  3. 在Django里面运行非项目文件

    2024-07-10 22:06:06       45 阅读
  4. Python语言-面向对象

    2024-07-10 22:06:06       55 阅读

热门阅读

  1. 深入理解UTF-8 Encoding在C#中的应用与异常处理

    2024-07-10 22:06:06       22 阅读
  2. Linux 常用命令 - mkdir【创建新目录】

    2024-07-10 22:06:06       19 阅读
  3. stm32实现IIC读写

    2024-07-10 22:06:06       22 阅读
  4. 中小企业和数智化的距离,只差一块华为IdeaHub

    2024-07-10 22:06:06       23 阅读
  5. C# —— Directory类

    2024-07-10 22:06:06       16 阅读
  6. 在Ubuntu 22.04上安装Docker最新版本

    2024-07-10 22:06:06       18 阅读