当前位置:首页 > 杂谈 > 正文内容

python使用 flask+vue 制作前后端分离图书信息管理系统-flask vue axios 前后端分离

2023-07-10 06:20:00TONY杂谈105

哈喽兄弟们,今天咱们来用Python实现一个前后端分离的图书信息管理系统。

制作前后端分离图书信息管理系统的思路:

1、前端部分

首先,我们可以使用 VueJS 作为前端框架,并通过 Vue CLI 工具进行创建和管理项目。

2、后端部分

后端部分我们可以采用 Python Flask 框架,这个框架是一个轻量级的Web框架,十分适合快速开发API接口。

3、前端和后端交互

前后端的交互可以采用 Restful API 设计的方式进行,例如创建一个图书列表接口,前端只需要发送一个 GET 请求给后端,后端通过查询数据库,返回 JSON 格式的数据给前端。

4、数据库

为了方便管理图书信息,我们可以使用关系型数据库 MySQL 存储和管理相关数据。

5、部署

可以使用 Docker 将前后端应用部署在同一个容器内,或者使用 CI/CD 工具将前后端应用分别部署在不同的服务器上。

总的来说,通过使用以上技术栈,我们就可以实现一个前后端分离的图书信息管理系统。

素材+代码

素材和全部代码、详细视频讲解,我都打包好了,扫码添加小助手

备注【LL】快速通过领取

效果展示

后端部分

flask: https://flask.palletsprojects.com/en/2.1.x/

flask-sqlalchemy: https://flask-sqlalchemy.palletsprojects.com/en/2.x/

flask-cors: https://flask-cors.readthedocs.io/en/latest/

flask 快速上手

from flask import Flask,

request

app = Flask(__name__)@app.route(/)def hello_world(): # put applications code herereturn Welcome Books!

数据库部分

# -*- coding: utf-8 -*-from extension import

db

class Book(db.Model):__tablename__ = bookid = db.Column(db.Integer, primary_key=True, autoincrement=True)book_number = db.Column(db.String(255), nullable=False)book_name = db.Column(db.String(255), nullable=False)book_type = db.Column(db.String(255), nullable=False)book_prize = db.Column(db.Float, nullable=False)author = db.Column(db.String(255))book_publisher = db.Column(db.String(255))@staticmethoddef init_db():rets = [(1, 001, 活着, 小说, 39.9, 余华, 某某出版社),(2, 002, 三体, 科幻, 99.8, 刘慈欣, 重庆出版社)]for ret in rets:book = Book()book.id = ret[0]book.book_number = ret[1]book.book_name = ret[2]book.book_type = ret[3]book.book_prize = ret[4]book.author = ret[5]book.book_publisher = ret[6]db.session.add(book)db.session.commit()

使用之前需要 flask create 初始化一下数据

接口部分

RESTful API 最佳实践(阮一峰) : https://www.ruanyifeng.com/blog/2018/10/restful-api-best-practice

s.html

Method Views for APIs: https://flask.palletsprojects.com/en/2.1.x/views/#method-views-for-apis

from flask import Flask,

request

from flask_cors import

CORS

from flask.views import

MethodView

from extension import

db

from models import

Book

app = Flask(__name__)CORS().init_app(app)app.config[SQLALCHEMY_DATABASE_URI] = sqlite:///books.sqliteapp.config[SQLALCHEMY_TRACK_MODIFICATIONS] = Falsedb.init_app(app)@app.cli.command()def create():db.drop_all()db.create_all()Book.init_db()@app.route(/)def hello_world(): # put applications code herereturn Welcome Books!class BookApi(MethodView):def get(self, book_id):if not book_id:books: [Book] = Book.query.all()results = [{id: book.id,book_name: book.book_name,book_type: book.book_type,book_prize: book.book_prize,book_number: book.book_number,book_publisher: book.book_publisher,author: book.author,} for book in

books

]return {status: success,message: 数据查询成功,results:

results

}book: Book = Book.query.get(book_id)return {status: success,message: 数据查询成功,result: {id: book.id,book_name: book.book_name,book_type: book.book_type,book_prize: book.book_prize,book_number: book.book_number,book_publisher: book.book_publisher,author: book.author,}}def post(self):form = request.

json

book = Book()book.book_number = form.get(book_number)book.book_name = form.get(book_name)book.book_type = form.get(book_type)book.book_prize = form.get(book_prize)book.author = form.get(author)book.book_publisher = form.get(book_publisher)db.session.add(book)db.session.commit()# id, book_number, book_name, book_type, book_prize, author,

book_publisher

return {status: success,message: 数据添加成功}def delete(self, book_id):book = Book.query.get(book_id)db.session.delete(book)db.session.commit()return {status: success,message: 数据删除成功}def put(self, book_id):book: Book = Book.query.get(book_id)book.book_type = request.json.get(book_type)book.book_name = request.json.get(book_name)book.book_prize = request.json.get(book_prize)book.book_number = request.json.get(book_number)book.book_publisher = request.json.get(book_type)book.author = request.json.get(book_type)db.session.commit()return {status: success,message: 数据修改成功}book_api = BookApi.as_view(book_api)app.add_url_rule(/books, view_func=book_api, methods=[GET, ], defaults={book_id: None})app.add_url_rule(/books, view_func=book_api, methods=[POST, ])app.add_url_rule(/books/<int:book_id>, view_func=book_api, methods=[GET,PUT, DELETE])

前端部分

vite: https://vitejs.cn/

vue3: https://v3.cn.vuejs.org/

Element Plus: https://element-plus.gitee.io/zh-CN/

axios: https://axios-http.com/docs/intro

项目创建

C:\Users\xxp\Desktop>

npm init vite@latest

√ Project name: ... book-

fontend

√ Select a framework:

» vue

√ Select a variant:

» vue

Scaffolding project in C:\Users\xxp\Desktop\book-fontend...Done. Now run:cd book-

fontend

npm install

npm run dev

项目初始化

npm install element-

plus

npm install axios

初始化 element-plus

import {createApp} from vueimport App from ./App.vueimport ElementPlus from element-plusimport element-plus/dist/index.cssconst app = createApp(App)app.use(ElementPlus)app.mount(#app)

页面创建

表单数据显示

<template><div style="margin: 0 auto;width: 50%;"><h1 style="text-align: center">图书管理系统</h1><!-- 添加图书按钮 --><el-button type="primary" @click="add_dialog_visible = true" size="small">

加图书</el-button><!-- 数据表格 --><el-table :data="books" style="margin: 20px auto;"><el-table-column label="编号" prop="book_number"/><el-table-column label="书名" prop="book_name"/><el-table-column label="类型" prop="book_type"/><el-table-column label="价格" prop="book_prize"/><el-table-column label="作者" prop="author"/><el-table-column label="出版社" prop="book_publisher"/><el-table-column align="right" label="操作" width="200px"><template #default="scope"><el-button size="small" @click="handleEdit(scope.$index, scope.row)">

编辑

</el-button><el-

button

size="small"type="danger"@click="handleDelete(scope.$index, scope.row)">

删除

</el-

button

></template></el-table-column></el-table></div></template><script setup>import axios from axiosimport {reactive, ref, onMounted} from "vue";import {ElMessageBox} from element-plusconst books = reactive([])const getStudents = () => {axios.get("http://localhost:5000/books",).then(res => {books.splice(0, books.length)books.push(...res.data.results)console.log(更新数据)})}//

页面渲染之后添加数据

onMounted(() => {getStudents()})//

删除数据

const handleDelete = (index, scope) => {axios.delete(`http://localhost:5000/books/${scope.id}`).then(() => {getStudents()})}</script>

添加数据

html表单

<!-- 添加图书页面 --><el-

dialog

title="添加图书"v-model="add_dialog_visible"width="30%":before-close="handleClose"><el-

form

ref="ruleFormRef":model="book_form"status-

icon

label-width="120px"class="demo-ruleForm"><el-form-item label="编号" prop="book_number"><el-input v-model="book_form.book_number" autocomplete="off"/></el-form-item><el-form-item label="书名" prop="book_name"><el-input v-model="book_form.book_name" autocomplete="off"/></el-form-item><el-form-item label="类型" prop="book_type"><el-input v-model="book_form.book_type" autocomplete="off"/></el-form-item><el-form-item label="价格" prop="book_prize">完整源码文档:加V:

python1018 备注【LL】快速通过领取

<el-input v-model.number="book_form.book_prize" autocomplete="off"/></el-form-item><el-form-item label="作者" prop="author"><el-input v-model="book_form.author" autocomplete="off"/></el-form-item><el-form-item label="出版社" prop="book_publisher"><el-input v-model="book_form.book_publisher" autocomplete="off"/></el-form-item><el-form-item><el-button type="primary" @click="submitForm(ruleFormRef)">提交</elbutton><el-button @click="resetForm(ruleFormRef)">重置</el-button></el-form-item></el-form></el-dialog>

JavaScript

/*表单添加*/const add_dialog_visible = ref(false)const ruleFormRef = ref()const book_form = reactive({book_number: "",book_name: "",book_type: "",book_prize: "",author: "",book_publisher: "",id: "",})//

表单提交事件

const submitForm = (formEl) => {完整源码文档:加V:

python1018 备注【LL】快速通过领取

axios.post(http://localhost:5000/books, book_form).then(() => {add_dialog_visible.value =

false

formEl.resetFields()getStudents()})}//

重置表单

const resetForm = (formEl) => {formEl.resetFields()}//

关闭弹窗前确认

const handleClose = (done) => {ElMessageBox.confirm(确认关闭?).then(() => {done();}).catch(() => {});}

好了,今天的分享就差不多到这里了!

对下一篇大家想看什么,可在评论区留言,看到我会更新的。

喜欢就关注一下博主,或点赞收藏评论一下我的文章吧!!!

“python使用 flask+vue 制作前后端分离图书信息管理系统-flask vue axios 前后端分离” 的相关文章

传世尊享(荣耀版),最大的智商税是这个

传世尊享(荣耀版),最大的智商税是这个

增额终身寿险的智商税分两种: 一种是明面上的智商税,如加减保未写入合同、现金价值偏低; 一种是隐藏很深的智商税,如把保额当成现金价值、混淆内部收益率(IRR)的计算方法。 今天,我们要聊的产品是,传世尊享(荣耀版),它的智商税共有3个,我们只聊其中最大的那一个,即现...

快递收到“精美礼物”?小心是骗局!

快递收到“精美礼物”?小心是骗局!

快递收到“精美礼物”? 填写个人信息后 还可以领取大额红包? 这样的好事 你心动了吗? 注意啦!!! 这极有可能是诈骗分子 设置好的陷阱! 一个简单的扫码动作 个人信息就有可能被盗取甚至转卖!!! 不法分子通过...

慢得跟不上时代,IE浏览器再见了!各种网上考试报名怎么办?

慢得跟不上时代,IE浏览器再见了!各种网上考试报名怎么办?

时代不断地进步,我们也在不停地和过去告别。 在超过25年后,微软终于要在明年退役IE浏览器(Internet Explorer)。...

58同城“移动经纪人”升级适用多类智能手环 助经纪人高效服务

58同城“移动经纪人”升级适用多类智能手环 助经纪人高效服务

房产服务线上化转移加强了经纪人对于智能手机的依赖,然而在线下带看中,出现了无法及时查看手机导致错过来自线上的用户消息和微聊信息等,以及各类软件消息众多导致找房用户信息被淹没等各类影响用户体验的问题。 近日,58同城、安居客升级经纪人作业工具“移动经纪人”即时信息互动功能,目前已适配...

京雄高速(北京段)覆盖移动5G专网

京雄高速(北京段)覆盖移动5G专网

中国移动北京公司近日宣布,京雄高速(北京段)已全线覆盖移动5G专网,北京移动与中国中铁集团及相关研究院合作研发的“车路协同系统”也正在加紧安装调试,将于年中开通全线应用。目前京雄高速(北京段)的最内侧车道已具备条件,被预留为“智能网联车专用车道”,未来将支持全路段自动驾驶。京雄高速(北京...

70城新房价格近八成环比上涨 3月份“小阳春”可期

70城新房价格近八成环比上涨 3月份“小阳春”可期

专家称,目前二手房供应充足,房价不会出现普遍性大幅上涨 本报记者 孟珂 伴随政策端继续发力,信贷环境相对宽松,房地产市场活跃度提升。3月16日,国家统计局发布数据显示,2月份,70个大中城市中,新建商品住宅和二手住宅销售价格环比上涨城市分别有55个和40个,比上月分别增加1...