91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python開發前后端分離的好處

發布時間:2021-09-04 14:08:47 來源:億速云 閱讀:124 作者:chen 欄目:編程語言

這篇文章主要介紹“python開發前后端分離的好處”,在日常操作中,相信很多人在python開發前后端分離的好處問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”python開發前后端分離的好處”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

在傳統的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的知識,我們前面蠻久前的一期Python學習教程中已經詳細的介紹過了,這里我們不再進行贅述。如果希望全面的了解和學習Vue.js,建議閱讀它的官方教程或者在YouTube上搜索Vue.js的新手教程(Crash Course)進行學習。

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

<!DOCTYPE html>
<html>
<head>
 <meta charset="UTF-8">
 <title>學科</title>
</head>
<body>
 <h2>所有學科</h2>
 <hr>
 <div id="app">
 <div v-for="subject in subjects">
 <h4>
 <a :href="getTeachersHref(subject.no)">{{ subject.name }}</a>
 <img v-if="subject.isHot" src="/static/images/hot.png" width="32">
 </h4>
 <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自帶的測試服務器,如果要嘗試前后端分離,可以先將靜態頁面放在之前創建的放靜態資源的目錄下。

到此,關于“python開發前后端分離的好處”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

晋州市| 葫芦岛市| 锡林郭勒盟| 青河县| 沅陵县| 汉源县| 满城县| 苗栗县| 竹溪县| 武宁县| 崇仁县| 碌曲县| 兴文县| 抚州市| 荆州市| 治多县| 芜湖县| 安吉县| 巴中市| 绥德县| 乐东| 环江| 谷城县| 台北县| 乳源| 天祝| 长沙市| 阿坝县| 衡阳市| 丰城市| 肥西县| 乌审旗| 保亭| 汝州市| 武夷山市| 阳城县| 遂溪县| 岳西县| 沙坪坝区| 武冈市| 托克逊县|