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

相关推荐

  • 路由器子网掩码网关设置(路由器子网掩码和网关怎么设置)

    路由器子网掩码网关设置(路由器子网掩码和网关怎么设置)   路由器是连接多个设备到互联网的关键设备之一。在配置路由器时需要设置子网掩码和网关,接下来我们来了解一下如何设置…

    网络 2025年11月24日
    274
  • excel负数显示红色怎么设置?

    Excel2010设置图标指定颜色表示负值。在Excel中制作条形图或柱形图时,默认所有的数据条(或柱形)都是同一种颜色的。有时会遇到数据为负值的情况,如果能设置在图表中用其他颜色表示负值将会更加醒目,那样会更加好的。现在小编就跟大家讲解一下Excel2010设置图标指定颜色表示负值。Excel2

    2021年9月8日
    42.2K
  • 正确设置无线路由器步骤

    原标题:"如何正确设置无线路由器教程"关于路由器设置教程分享。 - 来源:WiFi之家网 - 编辑:小元。
    一、正确设置无线路由器

      我所在的小区可以采用多种宽带接入方式,我选"

    路由器设置 2021年2月14日
    10.9K
  • 192.168.16.1可以做什么?

    192.168.16.1 IP地址是大多数无线路由器或ADSL调制解调器的默认网关。路由器可以使用多个IP作为登录地址,但是其中192.168.16.1是常见的地址之一。需要注意的是,不同品牌的路由器,默认的IP访问地址也是不一样的,而且一般还允许用户修改默认地址。因此具体的访问地址请参照说明书。

    路由器设置 2021年10月13日
    11.7K
  • 登录路由器页面地址 路由器登陆地址192.168.0.1和192.168.1.1

    原标题:"路由器登陆地址192.168.0.1和192.168.1.1"的相关路由设置资料分享。 - 来源:WiFi之家网 - 编辑:阿呆。

    现今市面上绝大部分品牌路由器采用的默认管理IP地址为英"

    2021年2月27日
    87.5K
  • ps怎么制作炫彩字体

    原标题:"怎么用ps制作炫彩字母"的相关路由器设置教程资料分享。- 来源:WiFi之家网。

    效果图

    制作步骤

    01

    [打开]PS软件,[新建]任意大小的画布。具体效果如图示。

    "

    路由器设置 2021年1月10日
    14.3K
  • 怎么设置副路由器wifi(怎么设置副路由器的ip)

    怎么设置副路由器WiFi(怎么设置副路由器的ip) 如果您家里的WiFi信号不够强,可以考虑添加一个副路由器来扩大覆盖范围。下面我们就来详细介绍一下如何设置副路由器的WiFi以及I…

    网络 2024年9月28日
    5.2K
  • k2路由器网址打不开的解决方法

    随着无线技术的发展与电脑的普及,一些朋友在上网过程中会碰到路由器设置网址192.168.1.1打不开的问题下面是学习啦小编为大家整理的关于k2路由器网址打不开,一起来看看吧! k2路由器网址打不开的解决方法 首先,要确定物理连接没有问题

    2021年10月20日
    14.6K
  • 迅捷fw150r路由器上不了网解决方法

    原标题:"迅捷fw150r路由器上不了网怎么办"相关路由器设置经验分享。 - 来源:WiFi之家网
      路由器上不了网很多原因是因为设置错误,下面是WiFi之家网为大家整理的关于迅捷fw150"

    2021年2月25日
    23.6K
  • 简述cpu的功能 CPU是干啥用的?

    简述cpu的功能 在电视上CPU起什么作用?CPU是干啥用的? 现在的液晶电视把他想象成放大了很多倍的平板电脑。原则上,两者是相同的产品类别。现在的电视机除了常规的电视信号编解码外,还恢复了红、绿

    投稿 2022年7月14日
    1.8K