前后端分离开发还不会?手把手教你了
off999 2025-01-07 14:55 23 浏览 0 评论
前后端分离开发入门
在传统的Web应用开发中,大多数的程序员会将浏览器作为前后端的分界线。将浏览器中为用户进行页面展示的部分称之为前端,而将运行在服务器,为前端提供业务逻辑和数据准备的所有代码统称为后端。所谓前后端分离的开发,就是前后端工程师约定好数据交互接口,并行的进行开发和测试,后端只提供数据,不负责将数据渲染到页面上,前端通过HTTP请求获取数据并负责将数据渲染到页面上,这个工作是交给浏览器中的JavaScript代码来完成。
使用前后端分离开发有诸多的好处,下面我们简要的说下这些好处:
- 提升开发效率。前后端分离以后,可以实现前后端代码的解耦,只要前后端沟通约定好应用所需接口以及接口参数,便可以开始并行开发,无需等待对方的开发工作结束。在这种情况下,前后端工程师都可以只专注于自己的开发工作,有助于打造出更好的团队。除此之外,在前后端分离的开发模式下,即使需求发生变更,只要接口与数据格式不变,后端开发人员就不需要修改代码,只要前端进行变动即可。
- 增强代码的可维护性。前后端分离后,应用的代码不再是前后端混合,只有在运行期才会有调用依赖关系,这样的话维护代码的工作将变得轻松愉快很多,再不会牵一发而动全身。当你的代码变得简明且整洁时,代码的可读性和可维护性都会有质的提升。
- 支持多终端和服务化架构。前后端分离后,同一套数据接口可以为不同的终端提供服务,更有助于打造多终端应用;此外,由于后端提供的接口之间可以通过HTTP(S)进行调用,有助于打造服务化架构(包括微服务)。
接下来我们就用前后端分离的方式来改写之前的投票应用。
返回JSON格式的数据
刚才说过,在前后端分离的开发模式下,后端需要为前端提供数据接口,这些接口通常返回JSON格式的数据。在Django项目中,我们可以先将对象处理成字典,然后就可以利用Django封装的JsonResponse向浏览器返回JSON格式的数据,具体的做法如下所示。
def show_subjects(request):
queryset = Subject.objects.all()
subjects = []
for subject in queryset:
subjects.append({
'no': subject.no,
'name': subject.name,
'intro': subject.intro,
'isHot': subject.is_hot
})
return JsonResponse(subjects, safe=False)上面的代码中,我们通过循环遍历查询学科得到的QuerySet对象,将每个学科的数据处理成一个字典,在将字典保存在名为subjects的列表容器中,最后利用JsonResponse完成对列表的序列化,向浏览器返回JSON格式的数据。由于JsonResponse序列化的是一个列表而不是字典,所以需要指定safe参数的值为False才能完成对subjects的序列化,否则会产生TypeError异常。
可能大家已经发现了,自己写代码将一个对象转成字典是比较麻烦的,如果对象的属性很多而且某些属性又关联到一个比较复杂的对象时,情况会变得更加糟糕。为此我们可以使用一个名为bpmappers的三方库来简化将对象转成字典的操作,这个三方库本身也提供了对Django框架的支持。
安装三方库bpmappers。
pip install bpmappers编写映射器(实现对象到字典转换)。
from bpmappers.djangomodel import ModelMapper
from poll2.models import Subject
class SubjectMapper(ModelMapper):
class Meta:
model = Subject修改视图函数。
def show_subjects(request):
queryset = Subject.objects.all()
subjects = []
for subject in queryset:
subjects.append(SubjectMapper(subject).as_dict())
return JsonResponse(subjects, safe=False)配置URL映射,然后访问该接口,可以得到如下所示的JSON格式数据。
[
{
"no": 101,
"name": "Python全栈+人工智能",
"intro": "Python是一种计算机程序设计语言。是一种面向对象的动态类型语言,最初被设计用于编写自动化脚本(shell),随着版本的不断更新和语言新功能的添加,越来越多被用于独立的、大型项目的开发。",
"create_date": "2017-08-01",
"is_hot": true
},
// 此处省略下面的内容
]如果不希望在JSON数据中显示学科的成立时间,我们可以在映射器中排除create_date属性;如果希望将是否为热门学科对应的键取名为isHot(默认的名字是is_hot),也可以通过修改映射器来做到。具体的做法如下所示:
from bpmappers import RawField
from bpmappers.djangomodel import ModelMapper
from poll2.models import Subject
class SubjectMapper(ModelMapper):
isHot = RawField('is_hot')
class Meta:
model = Subject
exclude = ('create_date', 'is_hot')再次查看学科接口返回的JSON数据。
[
{
"no": 101,
"name": "Python全栈+人工智能",
"intro": "Python是一种计算机程序设计语言。是一种面向对象的动态类型语言,最初被设计用于编写自动化脚本(shell),随着版本的不断更新和语言新功能的添加,越来越多被用于独立的、大型项目的开发。",
"isHot": true
},
// 此处省略下面的内容
]关于bpmappers详细的使用指南,请参考它的官方文档,这个官方文档是用日语书写的,可以使用浏览器的翻译功能将它翻译成你熟悉的语言即可。
使用Vue.js渲染页面
关于Vue.js的知识,我们在第21天到第30天(之前)的内容中已经介绍过了,这里我们不再进行赘述。如果希望全面的了解和学习Vue.js,我整理了视频版的学习教程,要学习的伙伴可以留言回复:“Python视频教程”,领取视频教程。
重新改写subjects.html页面,使用Vue.js来渲染页面。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>学科</title>
</head>
<body>
<h1>所有学科</h1>
<hr>
<div id="app">
<div v-for="subject in subjects">
<h3>
<a :href="getTeachersHref(subject.no)">{{ subject.name }}</a>
<img v-if="subject.isHot" src="/static/images/hot.png" width="32">
</h3>
<p>{{ subject.intro }}</p>
</div>
</div>
<script src="https://cdn.bootcss.com/vue/2.6.10/vue.min.js"></script>
<script>
const app = new Vue({
el: '#app',
data: {
subjects: []
},
created() {
fetch('/subjects/')
.then(resp => resp.json())
.then(json => this.subjects = json)
},
methods: {
getTeachersHref(sno) {
return `/static/teachers.html/?sno=${sno}`
}
}
})
</script>
</body>
</html>前后端分离的开发需要将前端页面作为静态资源进行部署,项目实际上线的时候,我们会对整个Web应用进行动静分离,静态资源通过Nginx或Apache服务器进行部署,生成动态内容的Python程序部署在uWSGI或者Gunicorn服务器上,对动态内容的请求由Nginx或Apache路由到uWSGI或Gunicorn服务器上。
在开发阶段,我们通常会使用Django自带的测试服务器,如果要尝试前后端分离,可以先将静态页面放在之前创建的放静态资源的目录下,不清楚的地方,可以留言!
之前建了个100天Python从新手到大神专栏,很多伙伴跟着学习,也收获了不少,也有伙伴跟我说希望出视频教程,看的直观些,这也整理出来了。
Python 900集全套视频教程https://pan.baidu.com/s/1cU5lDWq9gh0cQ7hCnXUiGA 提取码: m
要学习的伙伴,回复“Python视频教程”,领取!
相关推荐
-
- 电子邮箱地址是什么(遂宁的电子邮箱地址是什么)
-
邮箱被赋予的一个唯一的序号,就像我们居住的地址,用意确定收件人。Internet中每个用户的电子邮箱地址都具有惟一性,这样可使邮件的收发更加方便、准确。通常电子邮件地址的格式为:user@mail.server.name,其中user...
-
2025-12-10 23:03 off999
- win10下载到u盘要多久(win10下到u盘多少g)
-
Win10下载到U盘所需的时间取决于多种因素,包括您的网络速度、计算机性能和U盘的读写速度。如果您的网络速度较快,下载Windows10的时间应该不会太长。从下载到将Windows10安装到U盘上...
- c盘100g剩多少才合适(c盘100g还剩30g够用吗)
-
够用。但前提是我们只能把C盘当做系统盘,一般系统(win10)只占30到个40g,加上一些系统运行缓存文件,C盘剩下的空间大概在40到50个g。所以说你的其他软件千万不能安装在C盘了,安装在D盘或者F...
- 腾讯电脑管家官网网址(腾讯电脑管家介绍)
-
就是正常的输入你路由器的账户密码,如果你的默认密码没有修改。那你可以看看你路由器底下,底下一般会有路由器的初始账号密码。首先需要使用数据线链接,手机完成匹配之后,使用WIFI链接,会随机刷出验证码。一...
- 免费下载qq2025新版本手机(下载qq2020最新版)
-
1/4找到QQ注册的官网进入官网2/4填写信息申请页面中需要填写昵称,密码,验证码及其他信息,然后点击确定即可。3/4登录QQ完成上一步之后,页面上会显示申请的QQ号码,和登录QQ按钮,点击登录QQ。...
- win10模拟器电脑版下载(win10模拟器正版)
-
在Windows10模拟器上下载应用程序,可以按照以下步骤进行操作:1.打开Windows10模拟器:在电脑上打开Windows10模拟器软件,如MicrosoftVisualStudio...
- 微星主板开机自动进入bios(微星主板开机自动进入bios怎么关闭)
-
原因:一是硬盘的问题,二是bios设置错误。1、现在新型的主板都有快速启动模式,需要硬盘的支持,而且他会装入特定主板驱动,以达到开机几秒,让客户觉得这电脑很牛叉。缺点就是,一旦驱动程序出问题,或者系统...
- 深度技术windows下载(深度技术系统官网win10)
-
要下载原神,您可以按照以下步骤进行操作。首先,打开您的手机应用商店(如AppStore或GooglePlay),在搜索栏中输入“原神”。然后,找到原神游戏应用,并点击“下载”按钮。等待下载完成后,...
- 鼠标指针图案可爱(鼠标指针图片素材)
-
鼠标箭头使用什么颜色好?让我们在使用鼠标的时候,我们发现鼠标进到的同城是个白色,如果你想设置的话,你可以根据你的界面来,如果你的界面底色是白色,那么你就可以使用显眼的黑色和红色都可以,然后你自己喜欢什...
- 企业级tplink初始账号和密码
-
tplink管理员初始密码是admin。需要注意的是只有老款的tplink路由器才有默认的初始密码,可以在tplink路由器的铭牌标签上查看到,而新款的tp-link路由器没有默认的初始密码了,登录密...
- 台式电脑无internet访问(电脑无法连接网络无internet访问)
-
检查本机,方法:ping本机ip或127.0.0.1,若ping同通,则本机网络正常。若ping不通,则考虑重新安装tcp/ip网络协议。检查网络,方法:ping网关,若ping通,则网络正常。若p...
- 华为平板电脑系统怎么重装(华为平板电脑重装系统步骤)
-
1、当平板电量耗尽,刚插上充电器时可能无法立即开机,请持续充电一段时间,再开机使用。2、可能是系统故障,可以使用华为系统恢复(eRecovery)恢复平板系统版本。具体步骤:a、通过USB数据线将...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
使用 python-fire 快速构建 CLI_如何搭建python项目架构
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
