百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

前后端分离开发还不会?手把手教你了

off999 2025-01-07 14:55 27 浏览 0 评论

前后端分离开发入门

在传统的Web应用开发中,大多数的程序员会将浏览器作为前后端的分界线。将浏览器中为用户进行页面展示的部分称之为前端,而将运行在服务器,为前端提供业务逻辑和数据准备的所有代码统称为后端。所谓前后端分离的开发,就是前后端工程师约定好数据交互接口,并行的进行开发和测试,后端只提供数据,不负责将数据渲染到页面上,前端通过HTTP请求获取数据并负责将数据渲染到页面上,这个工作是交给浏览器中的JavaScript代码来完成。

使用前后端分离开发有诸多的好处,下面我们简要的说下这些好处:

  1. 提升开发效率。前后端分离以后,可以实现前后端代码的解耦,只要前后端沟通约定好应用所需接口以及接口参数,便可以开始并行开发,无需等待对方的开发工作结束。在这种情况下,前后端工程师都可以只专注于自己的开发工作,有助于打造出更好的团队。除此之外,在前后端分离的开发模式下,即使需求发生变更,只要接口与数据格式不变,后端开发人员就不需要修改代码,只要前端进行变动即可。
  2. 增强代码的可维护性。前后端分离后,应用的代码不再是前后端混合,只有在运行期才会有调用依赖关系,这样的话维护代码的工作将变得轻松愉快很多,再不会牵一发而动全身。当你的代码变得简明且整洁时,代码的可读性和可维护性都会有质的提升。
  3. 支持多终端和服务化架构。前后端分离后,同一套数据接口可以为不同的终端提供服务,更有助于打造多终端应用;此外,由于后端提供的接口之间可以通过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视频教程”,领取!

相关推荐

安全消防教育平台登录(消防安全教育网)

这个问题需要更明确的信息才能给出具体的解决方案。一般来说,如果你忘记了账号和密码,可以通过输入注册时填写的手机号或者邮箱来找回。如果有安全问题设置,也可以通过验证安全问题来找回。如果还是无法解决,可以...

音乐大全300首免费听(音乐歌曲大全免费)

1、《红昭愿》《红昭愿》,这首歌曲由音阙诗听演唱,音阙诗听在古风歌曲界早已有一定名气。这首《红昭愿》与他们之前的风格很相似,歌曲节奏欢快,其中掺杂了不同的音乐元素,融合在一起才有了这一动听的歌曲。2、...

搜狗输入法的优势(搜狗输入法的优势和劣势)

1、在输入50个左右的字符之后,搜狗输入法的耗电量为225μAh,只从绝对耗电量来看可以说是微乎其微的。但是如果是频繁使用,应该还是会耗一些电的。2、搜狗拼音输入法(简称搜狗输入法、搜狗拼音)是200...

直接下载mp3音乐的网站(直接下载mp3音乐的网站推荐)

说明书里有呀91flac音乐网,试试这个,绝对好使,但是不要在酷狗上面说有几个网站挺不错的一个酷猪首页上的歌曲都很好听还有一个是http://www.songtaste.com/music/这个网...

h5视频播放器(h5视频播放器适配竖屏模式)

要实现H5播放器在切换窗口时不暂停,可以使用WebAPI中的PageVisibilityAPI。该API允许开发者检测页面是否可见或隐藏。当页面切换到后台时,可以通过监听visibilitych...

云闪付app官方下载(云闪付官方下载最新版本)
  • 云闪付app官方下载(云闪付官方下载最新版本)
  • 云闪付app官方下载(云闪付官方下载最新版本)
  • 云闪付app官方下载(云闪付官方下载最新版本)
  • 云闪付app官方下载(云闪付官方下载最新版本)
百度云盘网页登录入口(百度网页入口官网网址)
百度云盘网页登录入口(百度网页入口官网网址)

手机登陆云盘可以通过更改UA设置来解决,方法如下:1.打开浏览器,点击进入浏览器的菜单选项。2.在设置的页面中,找到【浏览器标识/UA】,这个选项默认是【手机版】,即默认打开手机版网页。点击进入更改3.进入浏览器标识选择页面,将UA设置为电...

2026-02-03 00:15 off999

韩国色情大片震撼来袭

《千与千寻》导演:宫崎骏剧情简介:千寻和爸妈在去新家途中误入了一个诡异世界,爸妈因为贪吃变成了猪,许多半透明的怪人围攻千寻,幸被小白救下。小白给千寻吃了阻止身体消失的药,两人成为朋友。不料小白又被一...

天天斗地主单机(欢乐斗地主单机版免费)

有,可以在软件商店直接搜索单机斗地主。1.单机斗地主不要钱,不用流量。2.单机的玩法少,有单一的斗地主,闯关式的斗地主,残局式的斗地主,普通的斗地主。3.闯关式的斗地主,这种斗地主AI的水平都是控制...

最新网游(最新网游3d)

金山软件公司西山居工作室,于1995年5月在珠海成立,是国内最早的游戏开发工作室。1996年1月,西山居发布了中国大陆第一款商业游戏——《中关村启示录》,标志着金山公司正式进入游戏领域。龙骑士是首...

360一键重装系统(360一键重装系统后无法登录)

360并不提供自动重装系统的功能。重装系统是一项比较复杂的操作,需要对计算机硬件和软件有一定的了解,并且需要备份重要数据,重新安装操作系统和应用程序等。如果您需要重装系统,可以按照以下步骤进行操作:备...

免费离线单机斗地主(离线斗地主单机版免费)

想下载免流量不花钱斗地主,和麻将单机斗地主介绍:单机斗地主游戏是一款不需要联网的棋牌类手机游戏,此款斗地主最大的亮点是拥有强大的AI以及智能的提示功能。电脑具有很高的人工智能,为玩家提供了强劲的对手,...

58动漫(58动漫 官方入门网站)

打不开的原因可能有很多种,需要一一排查。首先要检查自己是否连接上了互联网,如果没有,就先联网。其次看一下叔叔有没有攻击。可能动漫网的版本比较低导致无法打开假的,58上面很多招聘工作跟他上线的信息不符合...

微信键盘输入法(微信键盘输入法下载)
  • 微信键盘输入法(微信键盘输入法下载)
  • 微信键盘输入法(微信键盘输入法下载)
  • 微信键盘输入法(微信键盘输入法下载)
  • 微信键盘输入法(微信键盘输入法下载)
精准客户电话号码采集软件(精准客户电话号码采集软件下载)

是正规平台。JMTOOL是一个采集工具软件。数据采集,又称数据获取,是利用一种装置,从系统外部采集数据并输入到系统内部的一个接口。数据采集技术目前广泛应用于各个领域。针对制造业企业的庞大生产数据,数据...

取消回复欢迎 发表评论: