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

boyanx2个月前技术教程7

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结合会更强大。整理并分享出来,喜欢就收藏和转发。

相关文章

Web前端【超出隐藏与显示】多种解决方案集锦

超出隐藏是指当某个元素内的内容,超出该元素的边界时,如何隐藏这些内容。overflowoverflow属性用于设置元素内容溢出时的处理方式。它有以下几个可能的取值:visible:默认值,不进行任何处...

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

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

Flask 数据可视化

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

57.后端必备的前端技巧

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

Flask+Pandas+CSV报表实现示例

以下是一个基于 Flask + Pandas + CSV 的简单报表实现示例,包含数据加载、处理和可视化展示:1. 项目结构bashflask-report/├── app.py├── data/│...

57challenges-56个挑战-客户端设计(part4)

上题目:接昨天:https://www.toutiao.com/article/7125986007236936226/昨天解决了前端界面格式化的问题,今天完成把json格式转化为excel表格,并供...

发表评论    

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