用Python+Eel写个Metro风格的web的GUI桌面程序

boyanx1周前技术教程3

1 说明

1.1 Eel是python的轻量级桌面GUI程序开发库。

1.2 已介绍,暂时略。讲一个用Python写个Metro风格的桌面程序。

1.3 资料来源,对代码进行注释。

https://www.jianshu.com/p/625da69a1d38
https://baijiahao.baidu.com/s?id=1613452977046555462

1.4 环境:deepin-linux深度操作系统,python3.8,谷歌浏览器,微软vscode编辑器。


2 文件结构:简单,一个main.py和一个web文件夹(里面有一个main.html)


3 main.py代码:

#---导出模块---
import eel
#---初始化,指定web文件夹,便于启动main.html文件
eel.init('web')
#---使用装饰器,类似flask里面对路由的定义---
@eel.expose
#---定义函数:python与html的联动设置---
def hello1():
    return '你好,python的eel'
#注意每一个函数都必须从新使用装饰器
@eel.expose
def hello2():
    return 'Eel很简单呀!'
#---启动的函数---调用放在最后,port=0表示使用随机端口,size=(宽,高)
#eel.start('main.html', port=0, size=(600,300))
eel.start('main.html')

4 main.html代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>用Python写个Metro风格的桌面程序</title>
    <link href="https://cdn.metroui.org.ua/v4/css/metro-all.min.css" rel="stylesheet">
    <script type="text/javascript" src="https://code.jquery.com/jquery-3.3.1.min.js"></script>
    <script type="text/javascript" src="https://cdn.metroui.org.ua/v4/js/metro.min.js"></script>
    <!--注意eel.js文件的导入;是eel的一大特点,与常见的js导入不同和vue也不同-->
    <!--这个"/eel.js"就是默认从你安装的eel模块中导出,也就是项目文件夹中无eel.js均可以,也就不存在本地和在线导入eel.js-->
    <script type="text/javascript" src="/eel.js"></script>
    <script>
        // 调用python中的函数,注意需要在定义前加上async声明异步
        async function show1val(){
            //调出python代码函数,关键点
            let text=  await eel.hello1()();
            $("#txt").val(text);
        }
        // 注意onclick的按钮函数在这里逐步添加,也就是py中的装饰器下的def定义函数
        async function show2val(){
            let text=  await eel.hello2()();
            $("#txt").val(text);
        }
    </script>

</head>
<body>
<nav data-role='ribbonmenu'>
    <ul class='tabs-holder'>
        <li><a href="#section-1-1">文件</a></li>
        <li><a href="#section-1-1">设置</a></li>
    </ul>
    <div class='content-holder'>
        <div class='section' id='section-1-1'>
            <div class='group'>
                <button class='ribbon-button' onclick='show1val()'>
                    <span class="mif-copy mif-5x fg-blue"></span>
                    <span class="caption">显示1</span>
                </button>
                <button class='ribbon-button' onclick='show2val()'>
                    <span class="mif-copy mif-5x fg-blue"></span>
                    <span class="title">显示2</span>
                </button>
                <span class="title">文本显示</span>
            </div>
            <div class='group'>
                <button class='ribbon-button'>
                    <span class="mif-copy mif-5x fg-blue"></span>
                    <span class="caption">github</span>
                </button>
                <button class='ribbon-button'>
                    <span class="mif-copy mif-5x fg-blue"></span>
                    <span class="title">gitlab</span>
                </button>
                <span class="title">提交</span>
            </div>
        </div>
    </div>
</nav>
<textarea  id="txt"  rows="100"></textarea>
</body>
</html> 

5 运行及效果图


很方面,如果和vue结合会更强大。整理并分享出来,喜欢就收藏和转发。

相关文章

通过免费CDN让你的网站打开速度加快N倍

网站开发者或网站管理者时常会用到一些JavaScript Libraries,例如最常见的jQuery或字体和CSS框架,通常不建议自己托管这些档案,因为除了耗流量,也可能因此拖慢网站的加载速度。为了...

前端架构师成长之路:避免将 JWT 存储在 localStorage 中

看到很多文章介绍将 JWT 存储在 localStorage 中,事实上,个人觉得建议最好不要。这就是将敏感信息存储在 localStorage 中,对于安全问题来说是个挑战,对于客户端的行为在安全问...

ThinkPHP 对接 DeepSeek 的教程(以 ThinkPHP 6.x 版本为例)

一、准备工作注册 DeepSeek 账号并获取 API Key查看 DeepSeek API 文档(假设接口地址为 https://api.deepseek.com/v1/chat/completio...

Flask 数据可视化

数据可视化是数据处理中的重要部分,前面我们了解了 Flask 的开发和部署,如何用 Flask 做数据可视化呢?今天我们来了解一下。Python 语言极富表达力,并且拥有众多的数据分析库和框架,是数据...

Spring Boot之集成WebSocket实现前后端通信,这你必须得会!

1. 前言这将又会是干货满满的一期,全程无尿点不废话只抓重点教,具有非常好的学习效果,拿好小板凳准备就坐!希望学习的过程中大家认真听好好学,学习的途中有任何不清楚或疑问的地方皆可评论区留言或私信,bu...

57.后端必备的前端技巧

文章目录前言1.jquery的两种按钮点击和发送请求:2.vue中的按钮定义和axios请求:总结前言现在都是前后端分离的开发,很多时候可能后端不会再写html,jquery了,但是一些场景之下后端还...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。