当前位置: 首页 > news >正文

Vue 3前端与Python(Django)后端接口简单示例

项目

    • 后端(Django)
    • 前端(Vue 3)

后端(Django)

  1. 创建Django项目和应用
    • 确保你已经安装了Django。如果没有安装,可以使用以下命令安装:
    pip install django
    
    • 创建一个新的Django项目:
    django-admin startproject myproject
    
    • 进入项目目录并创建一个新的应用程序:
    cd myproject
    python manage.py startapp myapp
    
  2. 配置项目
    • myproject/settings.py 文件中,将 myapp 添加到 INSTALLED_APPS 列表中,并配置允许跨域访问(因为Vue和Django可能运行在不同端口)。安装 corsheaders 库:
    pip install django-cors-headers
    
    • INSTALLED_APPS 中添加 corsheaders
    INSTALLED_APPS = [...'corsheaders','myapp',
    ]
    
    • MIDDLEWARE 中添加 corsheaders 中间件:
    MIDDLEWARE = ['corsheaders.middleware.CorsMiddleware','django.middleware.common.CommonMiddleware',...
    ]
    
    • 配置允许所有来源访问(在生产环境中请替换为实际的前端域名):
    CORS_ALLOW_ALL_ORIGINS = True
    
  3. 编写视图和API
    • myapp/views.py 中编写一个简单的视图函数:
    from django.http import JsonResponsedef get_data(request):data = {'message': '这是来自Django后端的数据'}return JsonResponse(data)
    
    • myapp/urls.py 中配置URL:
    from django.urls import path
    from. import viewsurlpatterns = [path('api/data/', views.get_data, name='get_data'),
    ]
    
    • myproject/urls.py 中包含 myapp 的URL配置:
    from django.contrib import admin
    from django.urls import path, includeurlpatterns = [path('admin/', admin.site.urls),path('', include('myapp.urls')),
    ]
    
  4. 运行后端
    python manage.py runserver
    

前端(Vue 3)

  1. 创建Vue 3项目
    • 确保你已经安装了 vue@latest。如果没有安装,可以使用以下命令安装:
    npm create vue@latest
    
    • 选择默认配置或根据提示进行自定义配置。
  2. 编写Vue组件
    • src/views/Home.vue 中修改代码以调用后端API:
    <template><div><h1>Vue 3与Django集成示例</h1><p>{{ responseData.message }}</p></div>
    </template><script setup>
    import { ref } from 'vue';
    import axios from 'axios';const responseData = ref({});const fetchData = async () => {try {const response = await axios.get('http://127.0.0.1:8000/api/data/');responseData.value = response.data;} catch (error) {console.error('Error fetching data:', error);}
    };fetchData();
    </script><style scoped>
    /* 样式 */
    </style>
    
  3. 运行前端
    • 在项目目录中运行以下命令启动Vue开发服务器:
    npm run dev
    

现在,Vue 3前端应用可以成功调用Django后端提供的API,并展示返回的数据。请确保后端和前端服务器都在运行,并且根据实际情况调整API的URL。

http://www.lryc.cn/news/520381.html

相关文章:

  • 《拉依达的嵌入式\驱动面试宝典》—操作系统篇(二)
  • STM32和国民技术(N32)单片机串口中断接收数据及数据解析
  • 【人工智能】大语言模型的微调:让模型更贴近你的业务需求
  • 大语言模型的稀疏性:提升效率与性能的新方向
  • Linux Bridge与Open vSwitch的工作原理及协作
  • async++源码阅读——task模块
  • 项目开发实践——基于SpringBoot+Vue3实现的在线考试系统(五)
  • EF Core一对一和多对多
  • 记一次sealos部署k8s集群之delete了第一台master如何恢复
  • vue3+vite+ts集成第三方js
  • android framework.jar 在应用中使用
  • FFmpeg入门
  • 云平台一键部署【Video-Background-Removal】视频换背景,无任何限制,随意换
  • 量子计算:从薛定谔的猫到你的生活
  • 51单片机——I2C-EEPROM
  • R语言的语法糖
  • 【算法学习笔记】30:埃氏筛(Sieve of Eratosthenes)和线性筛(Linear Sieve)
  • 【AscendC】tiling方案设计不当引起的一个时隐时现的bug
  • 视频转码对画质有影响吗?视频融合平台EasyCVR支持哪些转码格式?
  • 工业视觉2-相机选型
  • 基于SpringBoot+Vue的健身房管理系统
  • leetcode 面试经典 150 题:快乐数
  • Leetcode 279. 完全平方数 动态规划 完全背包问题
  • python学opencv|读取图像(三十三)阈值处理图像-限定像素
  • QT Quick QML 实例之椭圆投影,旋转
  • 炸砖块游戏的最终图案
  • LLM的实验平台有哪些:快速搭建测试大语言模型
  • python3GUI--大屏可视化-XX产业大数据指挥舱(附下载地址) By:PyQt5
  • .NET 9.0 的 Blazor Web App 项目中 Hash 变换(MD5、Pbkdf2) 使用备忘
  • uniapp 抖音小程序 getUserProfile:fail must be invoked by user tap gesture