真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Web前后端分離開發(fā)的方法是什么

本篇內(nèi)容主要講解“Web前后端分離開發(fā)的方法是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“Web前后端分離開發(fā)的方法是什么”吧!

創(chuàng)新互聯(lián)一直秉承“誠信做人,踏實(shí)做事”的原則,不欺瞞客戶,是我們最起碼的底線! 以服務(wù)為基礎(chǔ),以質(zhì)量求生存,以技術(shù)求發(fā)展,成交一個客戶多一個朋友!為您提供成都網(wǎng)站設(shè)計、做網(wǎng)站、成都網(wǎng)頁設(shè)計、微信小程序定制開發(fā)、成都網(wǎng)站開發(fā)、成都網(wǎng)站制作、成都軟件開發(fā)、重慶APP開發(fā)公司是成都本地專業(yè)的網(wǎng)站建設(shè)和網(wǎng)站設(shè)計公司,等你一起來見證!

在傳統(tǒng)的Web應(yīng)用開發(fā)中,大多數(shù)的程序員會將瀏覽器作為前后端的分界線。將瀏覽器中為用戶進(jìn)行頁面展示的部分稱之為前端,而將運(yùn)行在服務(wù)器,為前端提供業(yè)務(wù)邏輯和數(shù)據(jù)準(zhǔn)備的所有代碼統(tǒng)稱為后端。所謂前后端分離的開發(fā),就是前后端工程師約定好數(shù)據(jù)交互接口,并行的進(jìn)行開發(fā)和測試,后端只提供數(shù)據(jù),不負(fù)責(zé)將數(shù)據(jù)渲染到頁面上,前端通過HTTP請求獲取數(shù)據(jù)并負(fù)責(zé)將數(shù)據(jù)渲染到頁面上,這個工作是交給瀏覽器中的JavaScript代碼來完成。

使用前后端分離開發(fā)有諸多的好處,下面我們簡要的說下這些好處:

  1. 提升開發(fā)效率。前后端分離以后,可以實(shí)現(xiàn)前后端代碼的解耦,只要前后端溝通約定好應(yīng)用所需接口以及接口參數(shù),便可以開始并行開發(fā),無需等待對方的開發(fā)工作結(jié)束。在這種情況下,前后端工程師都可以只專注于自己的開發(fā)工作,有助于打造出更好的團(tuán)隊(duì)。除此之外,在前后端分離的開發(fā)模式下,即使需求發(fā)生變更,只要接口與數(shù)據(jù)格式不變,后端開發(fā)人員就不需要修改代碼,只要前端進(jìn)行變動即可。

  2. 增強(qiáng)代碼的可維護(hù)性。前后端分離后,應(yīng)用的代碼不再是前后端混合,只有在運(yùn)行期才會有調(diào)用依賴關(guān)系,這樣的話維護(hù)代碼的工作將變得輕松愉快很多,再不會牽一發(fā)而動全身。當(dāng)你的代碼變得簡明且整潔時,代碼的可讀性和可維護(hù)性都會有質(zhì)的提升。

  3. 支持多終端和服務(wù)化架構(gòu)。前后端分離后,同一套數(shù)據(jù)接口可以為不同的終端提供服務(wù),更有助于打造多終端應(yīng)用;此外,由于后端提供的接口之間可以通過HTTP(S)進(jìn)行調(diào)用,有助于打造服務(wù)化架構(gòu)(包括微服務(wù))。

接下來我們就用前后端分離的方式來改寫之前的投票應(yīng)用。

返回JSON格式的數(shù)據(jù)

剛才說過,在前后端分離的開發(fā)模式下,后端需要為前端提供數(shù)據(jù)接口,這些接口通常返回JSON格式的數(shù)據(jù)。在Django項(xiàng)目中,我們可以先將對象處理成字典,然后就可以利用Django封裝的JsonResponse向?yàn)g覽器返回JSON格式的數(shù)據(jù),具體的做法如下所示。

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)

上面的代碼中,我們通過循環(huán)遍歷查詢學(xué)科得到的QuerySet對象,將每個學(xué)科的數(shù)據(jù)處理成一個字典,在將字典保存在名為subjects的列表容器中,最后利用JsonResponse完成對列表的序列化,向?yàn)g覽器返回JSON格式的數(shù)據(jù)。由于JsonResponse序列化的是一個列表而不是字典,所以需要指定safe參數(shù)的值為False才能完成對subjects的序列化,否則會產(chǎn)生TypeError異常。

可能大家已經(jīng)發(fā)現(xiàn)了,自己寫代碼將一個對象轉(zhuǎn)成字典是比較麻煩的,如果對象的屬性很多而且某些屬性又關(guān)聯(lián)到一個比較復(fù)雜的對象時,情況會變得更加糟糕。為此我們可以使用一個名為bpmappers的三方庫來簡化將對象轉(zhuǎn)成字典的操作,這個三方庫本身也提供了對Django框架的支持。

安裝三方庫bpmappers。

pip install bpmappers

編寫映射器(實(shí)現(xiàn)對象到字典轉(zhuǎn)換)。

from bpmappers.djangomodel 
import ModelMapper

from poll2.models import Subject class SubjectMapper(ModelMapper):
 
   class Meta:
       model = Subject

修改視圖函數(shù)。

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格式數(shù)據(jù)。

[
   {
       "no": 101,
       "name": "Python全棧+人工智能",
       "intro": "Python是一種計算機(jī)程序設(shè)計語言。是一種面向?qū)ο蟮膭討B(tài)類型語言,最初被設(shè)計用于編寫自動化腳本(shell),隨著版本的不斷更新和語言新功能的添加,越來越多被用于獨(dú)立的、大型項(xiàng)目的開發(fā)。",
       "create_date": "2017-08-01",
       "is_hot": true
   },
   // 此處省略下面的內(nèi)容
]

如果不希望在JSON數(shù)據(jù)中顯示學(xué)科的成立時間,我們可以在映射器中排除create_date屬性;如果希望將是否為熱門學(xué)科對應(yīng)的鍵取名為isHot(默認(rèn)的名字是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')

再次查看學(xué)科接口返回的JSON數(shù)據(jù)。

[
   {
       "no": 101,
       "name": "Python全棧+人工智能",
       "intro": "Python是一種計算機(jī)程序設(shè)計語言。是一種面向?qū)ο蟮膭討B(tài)類型語言,最初被設(shè)計用于編寫自動化腳本(shell),隨著版本的不斷更新和語言新功能的添加,越來越多被用于獨(dú)立的、大型項(xiàng)目的開發(fā)。",
       "isHot": true
   },
   // 此處省略下面的內(nèi)容
]

關(guān)于bpmappers詳細(xì)的使用指南,請參考它的官方文檔,這個官方文檔是用日語書寫的,可以使用瀏覽器的翻譯功能將它翻譯成你熟悉的語言即可。

使用Vue.js渲染頁面

關(guān)于Vue.js的知識,我們在第21天到第30天(之前)的內(nèi)容中已經(jīng)介紹過了,這里我們不再進(jìn)行贅述。如果希望全面的了解和學(xué)習(xí)Vue.js,我整理了視頻版的學(xué)習(xí)教程,要學(xué)習(xí)的伙伴可以留言回復(fù):“Python視頻教程”,領(lǐng)取視頻教程。

重新改寫subjects.html頁面,使用Vue.js來渲染頁面。




   
   學(xué)科


   

所有學(xué)科


   

   

       

           


               {{ subject.name }}
               
           


           

{{ subject.intro }}


       

   

   
   

前后端分離的開發(fā)需要將前端頁面作為靜態(tài)資源進(jìn)行部署,項(xiàng)目實(shí)際上線的時候,我們會對整個Web應(yīng)用進(jìn)行動靜分離,靜態(tài)資源通過Nginx或Apache服務(wù)器進(jìn)行部署,生成動態(tài)內(nèi)容的Python程序部署在uWSGI或者Gunicorn服務(wù)器上,對動態(tài)內(nèi)容的請求由Nginx或Apache路由到uWSGI或Gunicorn服務(wù)器上。

到此,相信大家對“Web前后端分離開發(fā)的方法是什么”有了更深的了解,不妨來實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!


分享標(biāo)題:Web前后端分離開發(fā)的方法是什么
標(biāo)題鏈接:http://weahome.cn/article/jhshpj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部