Python写一个电子发票管理工具2:前端界面开发

用一系列文章介绍如何用Python写一个发票管理小工具。

发票管理小工具要支持B/S和C/S两种部署模式,因为涉及到发票这种隐私数据,能够安装到自己电脑运行可能是大部分人更能接受的方式。

先看一下最终的页面效果。

Python写一个电子发票管理工具2:前端界面开发

发票夹页面

Python写一个电子发票管理工具2:前端界面开发

设置页面

Python写一个电子发票管理工具2:前端界面开发

添加抬头页面

技术选型

这个工具我不用通常的Python可视化编程如tkinter或Qt来开发PC客户端,给大家介绍一个不太一样的套路,采用前后端分离的模式来实现。

使用FastAPI做服务端,Vue做前端页面。

B/S模式将程序部署到服务器,用户使用浏览器访问即可;C/S模式用python自动打开浏览器页面的方式来运行,打包成exe下载安装。

需求梳理

首先简单地用思维导图将页面需求整理一下。主要分为两个功能模块:发票管理(取名发票夹)和设置。发票夹功能为发票的增删改查以及导入导出。设置目前包括抬头管理和自定义费用类型管理。

Python写一个电子发票管理工具2:前端界面开发

CDN模式使用ElementPlus

对Vue熟悉的朋友看下面的内容就相当简单了,用Vue3和ElementPlus开发网页。对于网页前端或Vue不太熟悉的朋友可以先看一下Vue的文档和ElementPlus的文档,Vue学习起来还是很简单的。

因为功能很简单这里我直接使用一个单页面来开发这个页面,这样用Vue就相当于Jquery一样。不需要nodejs,不需要脚手架,使用起来相当简单。但是这种用法仅限于类似的简单项目,稍微多几个页面还是需要模块化开发,便于代码复用、代码阅读和代码管理。

首先我们用ElmentPlus提供的CDN引入模式(注意:CDN不稳定网站就无法显示了)写一个有两个菜单的页面,通过点击菜单切换显示的内容。这里需要引入vue、element-plus的css和js()。

说明1:可以通过浏览器调试界面查看当前使用的vue和elementplus版本,在CDN链接中指定版本和实际css与js链接,这样可以避免版本升级后引入问题,并且省去几次302跳转加快加载时间。

说明2:C/S版本将css和js都下载到本地打包,不使用CDN。


Python写一个电子发票管理工具2:前端界面开发


我的发票夹

发票夹
设置

发票夹
设置

Python写一个电子发票管理工具2:前端界面开发

使用Icon图标

新版的ElementPlus提供了CDN模式的Icon,需要引入以下js,并且对图标组件进行全局注册。


const app = Vue.createApp(App);
app.use(ElementPlus);
//注册icon组件
for (const [key, component] of Object.entries(ElementPlusIconsVue)) {
app.component(key, component);
}

下面为发票夹和设置添加图标:

发票夹
设置

Python写一个电子发票管理工具2:前端界面开发

图标就出来了

注意1:直接复制ElementPlus示例代码到html中是不能正常显示的,因为这样单标签的写法是不可以的,因为这些标签都不是html原生的标签,必须写成这样的双标签。

注意2:使用两个或以上单词的组件,如,需要使用-隔开单词。

当然,不使用Icon组件,直接使用SVG也可以。例如上面的folder图标,将源码中的SVG直接拷贝出来使用就可以。



国际化

因为ElementPlus默认语言是英语,所以需要引入中文国际化组件才能显示中文。引入方法如下:


app.use(ElementPlus, {locale: ElementPlusLocaleZhCn,});

JS加载完再显示页面

这样的单html页面,在js加载完之前,会显示一些页面标签和文字,然后再展示正常页面。如下图:

Python写一个电子发票管理工具2:前端界面开发

可以先将body设置为不显示,然后onload后再显示。


......

页面代码

页面就是施展CV大法了,选择需要使用的组件,将ElementPlus页面上的示例代码拷贝粘贴,修改样式和JS代码,基础页面就写完了。接下来就是定义接口、设计数据库和编写前后端逻辑代码了~

我的发票夹




发票夹
设置

开票时间
导入时间

搜索
重置

批量导入

手动添加

删除

导出

Excel报表
合并PDF发票

设置费用类型

{{item}}

设置发票状态

已使用
未使用

名称: {{ scope.row.seller_name }}
税号: {{ scope.row.seller_tax_number }}

{{ scope.row.seller_name }}

<!-- -->

修改
删除

添加抬头

用于校验有效发票抬头

修改
删除

{{ tag }}

+ 添加费用类型

确定
取消

以上内容来源于网络,由“WiFi之家网”整理收藏!

原创文章,作者:电脑教程,如若转载,请注明出处:https://www.224m.com/218523.html

(0)
电脑教程电脑教程
宽带密码忘记查看路由器宽带密码的方法(附路由器密码查看器下载地址)
上一篇 2023年2月20日 08:14
表格导入功能(表格导入功能在哪里)
下一篇 2023年2月20日 08:22

相关推荐

  • 电脑桌面壁纸防止被修改设置方法

    原标题:"电脑桌面壁纸怎么防止被修改 锁定电脑桌面背景的方法"关于电脑问题教程分享。 - 来源:WiFi之家网。电脑桌面背景怎么防止被更改呢?不少人都会遇到电脑借出去后被修改桌面壁纸的问题,其实我们可以

    2021年7月23日
    8.1K
  • 路由器页面设置在哪里(如何登录路由器设置页面)

    路由器页面设置在哪里? 路由器是我们在家庭网络中经常使用的设备,它能够将互联网信号转换为WiFi信号,为我们的网络使用提供便利。当我们需要配置路由器时,就需要登录到路由器的设置页面…

    网络 2024年8月28日
    137
  • 华硕asus路由器登录入口

    华硕asus路由器登录入口 华硕asus路由器是一款受欢迎的路由器品牌,它提供了一些卓越的功能和性能,让用户可以方便地管理和保护他们的网络。如果你是一名华硕asus路由器用户,那么…

    2023年9月6日
    12
  • 某大型网络的配置实例

    说明: 这是一个比较综合的实例,从拓扑图上可以看出,它所包含的设备和技术。以下对这个例子作些说明希望能够和各位网友交流。 1.对于内部局域网,选用Cisco的Catalyst6506作为中心交换机,二级交换采用Catalyst3500,同时为了说明Trunk,又加了一个Catalyst2900作为交"

    路由器设置 2021年2月18日
    7.4K
  • 路由器设置不显示账户名(路由器设置入口)

    路由器设置不显示账户名(路由器设置入口) 最近很多用户反映,在登陆路由器设置入口的时候,出现了账户名不显示的情况。这让很多用户感到不知所措,下面我们就来看一下这个问题的解决方法。 …

    网络 2025年12月4日
    0
  • 路由器ip地址设置页面(为什么搜路由器ip地址页面点不进去)

    路由器IP地址设置页面 很多人在搜寻路由器IP地址设置页面的时候,发现点击进去会出现各种问题,比如页面打不开、无法登录等。那么这是为什么呢? 首先,我们需要明确一个概念:路由器IP…

    网络 2024年9月12日
    0
  • 路由器500m要怎么设置(新路由器怎么设置才能用)

    路由器500m要怎么设置(新路由器怎么设置才能用) 新购买的路由器一般默认是未设置状态,需要我们进行一些基本的设置才能正常使用。以下是路由器500m的设置方法: 步骤1:连线 将路…

    网络 2025年11月19日
    0
  • 华为路由器ws5200增强版 华为WS5200路由器wifi密码

    原教程:"华为WS5200路由器wifi密码怎么设置?"的相关最新路由设置教程资料分享。 - 来源:WiFi之家网 - 编辑:小歪。

    本文给大家详细介绍,使用电脑设置华为WS5200"

    路由器设置 2021年1月24日
    16.6K
  • 192.168.0.1手机版入口

    随着智能手机的普及,越来越多的人开始使用手机进行网络设置和管理。而对于路由器等网络设备的管理,也需要相应的手机版入口。其中,192.168.0.1是一个常见的路由器管理地址,那么有…

    2023年5月24日
    11
  • TP-Link TL-WR840N V7~V9 无线路由器映射服务器到外网操作指南

    1、进入虚拟服务器设置界面 登录路由器管理界面,点击“应用管理”,进入应用中心,如下图: 找到虚拟服务器,点击“进入”,如下: 2、添加映射条目及规则 点击“添加”按钮,如下: 输…

    2023年5月13日
    11