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

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

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

哈喽兄弟们,今天咱们来用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 前后端分离” 的相关文章

知云学子成长变化,努力从不是说说而已

知云学子成长变化,努力从不是说说而已

从青葱校园到大千世界 从懵懂少年到职场精英 一千多个日夜 让莘莘学子 在知云时代校企合作院校中 创造出属于自己的奇迹 几年的光阴 他们改变的不止是过往与当下 更是未来实训基地伴成长»»同成长 共辉煌...

ChatGPT救不了云知声

ChatGPT救不了云知声

原标题:ChatGPT救不了云知声 撰文 | 因 客 编辑 | 杨博丞 题图 | IC Photo 日前,云知声召开了一场主题为“AI 赋能临床:从助手到专家”的医疗AI产品发布会。云知声表示,“医疗语音交互解决方案”是目前落地、应用相对成熟的产...

爱普生L3158 3156 3153 3151系列打印机重新设置wifi密码的步骤

爱普生L3158 3156 3153 3151系列打印机重新设置wifi密码的步骤

此文章适合爱普生L31系列 3158 3156 3153 3151等等适用场景:1、家里wifi的SSID和密码都换了;2、家里wifi的密码都换了;3:搬家什么都不记得了。更换打印机的wifi的ssid和密码的方法有2种:第一种:爱普生官网上的方法,这个方法的前提是打印机direct网络的密码是默...

网站推荐|7个高质量Icon图标资源网站

网站推荐|7个高质量Icon图标资源网站

无论是界面设计还是PPT设计,一款有吸引力的精美图标,可以让我们的作品更具视觉标识。但是现在的Icon网站有很多,但是真正好用的,我只推荐下面这几个。大家如果有需要,建议收藏分享。 1、Iconfont-阿里巴巴矢量图标库 网址 http://www.iconfont.cn...

原创
            成吉思汗曾经打下的江山如今都包含了哪些国家

原创 成吉思汗曾经打下的江山如今都包含了哪些国家

原标题:成吉思汗曾经打下的江山如今都包含了哪些国家 蒙古帝国作为人类历史上连续版图最大的帝国在全盛时期的疆域高达3300万平方公里。蒙古人自东向西从中亚一直打到西亚乃至深入欧洲腹地,又从严寒的漠北草原一路向南直达南海之滨。如今在昔日蒙古帝国的版图上分布着蒙古、中国、俄罗斯、哈萨克...

2023年世界知识产权日,探索知识产权公益新路径

2023年世界知识产权日,探索知识产权公益新路径

  2023年4月26日,世界知识产权日,同时也是才标网一站式知识产权服务平台正式上线七周年。才标网围绕2023年世界知识产权日主题——“女性和知识产权:加速创新创造”,于当天举办“温情筑梦 与爱同行”才标公益基金发布暨妇联成立大会,借助妇联成立之契机,探索知识产权公益新路径,关爱妇女儿童...