【Flask+VUE】flask+vue开发web网页系统(详细安装使用范例)

【Flask+VUE】flask+vue开发web网页系统(详细安装使用范例)

【Flask_VUE】flask+vue开发web网页系统(详细安装使用范例)


使用 Flask + Vue 开发 Web 网页系统是一种常见的前后端分离架构:Flask 作为后端提供 RESTful API 接口,Vue 作为前端构建单页面应用(SPA)。下面我将为你提供一个 详细的安装与使用范例,包括项目结构、环境搭建、接口通信、跨域处理等关键步骤。

✅ 一、项目结构规划

flask-vue-web-system/ │ ├── backend/ # Flask 后端 │ ├── app.py # 主程序 │ ├── models.py # 数据模型(可选) │ └── requirements.txt # Python依赖 │ └── frontend/ # Vue 前端 ├── public/ ├── src/ │ ├── views/ │ ├── components/ │ ├── services/ # API 请求服务 │ ├── App.vue │ └── main.js ├── package.json └── vue.config.js # 配置代理解决跨域 

✅ 二、后端:Flask 搭建 API 服务

1. 安装 Flask 并创建后端项目

mkdir flask-vue-web-system cd flask-vue-web-system mkdir backend cd backend python -m venv venv source venv/bin/activate # Linux/Mac# 或 venv\Scripts\activate # Windows

安装依赖:

pip install flask flask-cors 

保存依赖:

pip freeze > requirements.txt 

2. 编写 app.py

# backend/app.pyfrom flask import Flask, jsonify, request from flask_cors import CORS # 解决跨域问题 app = Flask(__name__) CORS(app)# 允许前端访问(开发时)# 模拟数据 users =[{"id":1,"name":"Alice","email":"[email protected]"},{"id":2,"name":"Bob","email":"[email protected]"}]# GET /api/users - 获取用户列表@app.route('/api/users', methods=['GET'])defget_users():return jsonify(users)# POST /api/users - 添加新用户@app.route('/api/users', methods=['POST'])defadd_user(): data = request.get_json() new_id =max(u["id"]for u in users)+1if users else1 user ={"id": new_id,"name": data["name"],"email": data["email"]} users.append(user)return jsonify(user),201# 启动入口if __name__ =='__main__': app.run(host='0.0.0.0', port=5000, debug=True)

3. 运行后端服务

cd backend python app.py 

访问 http://localhost:5000/api/users 可看到 JSON 数据。


✅ 三、前端:Vue 搭建用户界面

1. 创建 Vue 项目(需要 Node.js 和 npm)

确保已安装 Node.js(建议 v16+),然后:

cd../frontend npm create vue@latest # 选择默认选项即可(或手动启用 Router、Pinia)cd frontend npminstall

2. 安装 Axios(用于 HTTP 请求)

npminstall axios 

3. 创建 API 服务文件

创建 src/services/api.js

// src/services/api.jsimport axios from'axios'const apiClient = axios.create({baseURL:'http://localhost:5000',// Flask 后端地址headers:{'Content-Type':'application/json'}})exportdefault{getUsers(){return apiClient.get('/api/users')},addUser(user){return apiClient.post('/api/users', user)}}

4. 创建用户列表组件(src/views/UserList.vue

<!-- src/views/UserList.vue --> <template> <div> <h2>用户列表</h2> <ul> <li v-for="user in users" :key="user.id"> {{ user.name }} ({{ user.email }}) </li> </ul> <h3>添加用户</h3> <form @submit.prevent="handleSubmit"> <input v-model="name" placeholder="姓名" required /> <input v-model="email" placeholder="邮箱" type="email" required /> <button type="submit">添加</button> </form> </div> </template> <script> import api from '@/services/api' export default { name: 'UserList', data() { return { users: [], name: '', email: '' } }, async created() { try { const response = await api.getUsers() this.users = response.data } catch (error) { console.error('获取用户失败:', error) } }, methods: { async handleSubmit() { try { const response = await api.addUser({ name: this.name, email: this.email }) this.users.push(response.data) this.name = '' this.email = '' } catch (error) { console.error('添加用户失败:', error) } } } } </script> <style scoped> .user-list { max-width: 600px; margin: 2rem auto; padding: 1rem; } input { display: block; width: 100%; margin: 0.5rem 0; padding: 0.5rem; } button { margin-top: 1rem; padding: 0.5rem 1rem; } </style> 

5. 配置路由(使用 Vue Router)

编辑 src/router/index.js

import{ createRouter, createWebHistory }from'vue-router'import UserList from'../views/UserList.vue'const routes =[{path:'/',component: UserList }]const router =createRouter({history:createWebHistory(), routes })exportdefault router 

src/main.js 中挂载:

import{ createApp }from'vue'import App from'./App.vue'import router from'./router'createApp(App).use(router).mount('#app')

6. 修改 App.vue

<!-- src/App.vue --> <template> <div> <router-view /> </div> </template> <script> export default { name: 'App' } </script> 

7. (可选)配置代理避免跨域(生产中应由 Nginx 处理)

创建 vue.config.js 在项目根目录(frontend/vue.config.js):

// frontend/vue.config.js module.exports ={devServer:{proxy:{'/api':{target:'http://localhost:5000',changeOrigin:true,secure:false}}}}

修改 api.jsbaseURL 为相对路径:

baseURL:'/api'// 而不是 http://localhost:5000

这样开发时请求 /api/users 会被代理到 http://localhost:5000/api/users


✅ 四、运行项目

启动后端(终端 1):

cd backend source venv/bin/activate # 激活虚拟环境 python app.py 

启动前端(终端 2):

cd frontend npm run dev 

打开浏览器访问:http://localhost:5173


✅ 五、部署建议(生产环境)

  1. Flask 提供静态文件(可选方案)将 Vue 打包后的文件放入 Flask 的 static/templates/index.html,或者用 Nginx 托管前端,Flask 单独做 API 服务。
  2. 使用 Gunicorn + Nginx 部署 Flask
  3. 使用 Nginx 同时托管前端和反向代理 API

前端打包

cd frontend npm run build 

生成 dist/ 目录。


✅ 总结说明

  • Flask 负责提供 JSON 接口,处理业务逻辑和数据库。
  • Vue 负责构建交互式前端界面,通过 Axios 调用接口。
  • CORS 或 devServer.proxy 解决开发期跨域问题。
  • 前后端分离 提高开发效率和维护性。

Read more

GitHub 国内镜像可用站点 亲测可用 202502更新

01.GitHub 镜像可用站点 镜像访问链接可用GitHub镜像站014直接https://bgithub.xyz可用GitHub镜像站013直接https://kkgithub.com可用GitHub镜像站012直接https://gitclone.com可用GitHub镜像站011直接https://github.hscsec.cn不可用GitHub镜像站010直接https://git.homegu.com不可用GitHub镜像站009直接https://github.ur1.fun可用GitHub镜像站008直接https://git.homegu.com不可用GitHub镜像站007文件加速https://moeyy.cn/gh-proxy/可用GitHub镜像站006文件加速https://ghp.ci/可用GitHub镜像站005文件加速https://gh-proxy.com/可用GitHub镜像站004文件加速https://ghproxy.net/可用GitHub镜像站003文件加速https://ghproxy.homeboyc.cn/可用GitHub镜像

By Ne0inhk

【AI大模型学习日志7:深度拆解阿里通义千问Qwen——产业级AI基建与全球开源生态的双轮驱动者】

在上一篇 AI 大模型学习日志中,我们完整拆解了字节跳动旗下的豆包系列,它以极致的普惠化设计、全模态原生能力,让 AI 技术走进了亿级中国用户的日常生活,成为国内 C 端通用 AI 的国民级标杆。而当我们把视线投向决定行业长期格局的企业级市场与全球开源生态,有一款产品走出了国内大模型独一份的发展路径 —— 它没有陷入 “to C 流量内卷” 或 “to B 政企单一赛道” 的固化思维,从立项之初就确立了“闭源做产业深度、开源做全球生态”的双线并行战略,不仅闭源旗舰性能对标国际顶尖水平,更成为了全球第二大开源大模型体系,是唯一打入全球主流开源生态的中国大模型,它就是阿里巴巴达摩院联合阿里云打造的通义千问 Qwen 系列。 在国内大模型普遍陷入 “要么闭源做黑箱服务,要么开源做小参数模型” 的二元对立时,通义千问用三年时间证明:开源与闭源并非非此即彼的选择,极致的产业落地能力与全球化的开源生态可以双向赋能、互相成就。本文所有核心信息均以阿里云官方技术白皮书、达摩院技术论文、官方发布公告与开源文档为唯一基准,严格遵循系列日志的统一框架,从官方定义与核心基本面、完整发展历程、解决的行业核心痛

By Ne0inhk
最强开源多模态大模型它来啦——一文详解Qwen3.5核心特性

最强开源多模态大模型它来啦——一文详解Qwen3.5核心特性

前言 各位小伙伴新年好!新的一年祝大家龙马精神、阖家幸福、身体健康、事业进步!2025 年 DeepSeek 发布的 DeepSeek-R1 模型震惊全球,此后国内各大厂商充分发挥“能征善战”的拼劲,纷纷选择重大节日推出新品。今年除夕夜,阿里 Qwen 团队再次放出大招——Qwen3.5 模型正式开源,为国产大模型阵营再添一员猛将。 Qwen3.5 是目前全球最强的原生多模态开源大模型,不仅支持图片和视频的多模态输入,在对话、推理、编程、Agent 构建等方面也样样精通。其综合能力已达到 GPT-5.2、Gemini 3.0 Pro 的平均水平,推理能力尤为突出。例如那道曾让无数模型“翻车”的逻辑题——“50 米距离该走路还是开车去洗车”,Qwen3.5 也能轻松作答。

By Ne0inhk

【超详细】VSCode连接GitHub全攻略:上传/克隆代码一步到位

一、前言 * 为什么要用VSCode + GitHub? * GitHub:全球最大代码托管平台,支持版本控制和协作开发 * VSCode:轻量级代码编辑器,内置Git支持,无缝集成GitHub * 适用场景:个人项目管理、团队协作、开源贡献 二、准备工作 1. 注册GitHub账号 * 访问 GitHub官网 注册账号 * 验证邮箱(重要!否则无法推送代码) 2. 安装必要工具 * VSCode:官网下载 * Git:官网下载 * 安装时勾选 "Add Git to PATH" 3. 配置Git全局信息(必做!) git config --global user.name "你的GitHub用户名" git

By Ne0inhk