无码专区一区人妻|人妻系列一区二区播放|国产免费牲交大片高清|日韩黄色无码一区二区三区|久久精品国产亚洲二区三区|欧美综合在线一区二区三区|精品无码国产自产拍在线观看蜜|999zyz精品视频在线播放

您當(dāng)前的位置 :寧夏資訊網(wǎng) > 消費(fèi) >  內(nèi)容正文
投稿

Django開發(fā)者常犯的7種錯誤

寧夏資訊網(wǎng) 2020-03-23 08:31:22 來源: 閱讀:-

Django是一個強(qiáng)大的web框架,但是它的強(qiáng)大也帶來了責(zé)任。在本文中,我們將討論即使是經(jīng)驗(yàn)豐富的Django開發(fā)人員也會犯的常見錯誤,但是大多數(shù)成功的Django項(xiàng)目遲早都需要處理這些錯誤。

重新發(fā)明輪子

Django有很多現(xiàn)成的特性,甚至還有更多的第三方包。試著在寫代碼之前“google”一下您想解決的問題——可能已經(jīng)有一個功能豐富的解決方案了。

您還可以使用在線目錄“Django項(xiàng)目”,其中“apps”類別中(用于構(gòu)建項(xiàng)目的小組件)有超過3200個項(xiàng)目。以下是來自清單前兩頁的有趣包的簡短示例:

  • Haystack:用于Django的模塊搜索

  • Django-taggit:用于Django的簡單標(biāo)記

  • Django-guardian:用于Django的每個對象的權(quán)限

  • Django-activity-stream:從站點(diǎn)上的操作生成通用的活動流。用戶可以跟蹤任何參與者的個性化流的活動。

額外提示:我強(qiáng)烈推薦使用cookiecutter-django啟動一個新的Django項(xiàng)目。它有一個自定義的用戶模型,通過django-allauth進(jìn)行注冊,通過Anymail發(fā)送電子郵件,以及許多與安全和部署相關(guān)的默認(rèn)設(shè)置。

龐大的應(yīng)用程序結(jié)構(gòu)

Django是一個松散耦合的框架,它不要求您以任何特定的方式來構(gòu)建web應(yīng)用程序。然而,經(jīng)驗(yàn)豐富的Django開發(fā)人員有一種標(biāo)準(zhǔn)的做事方式。

Django web應(yīng)用程序的基本單元是由一個或多個app組成的Django項(xiàng)目。Django app是一個自包含的包,它應(yīng)該只做一件事。例如一個博客、會員app或事件日歷。

Django app可以包含Python模塊、特定于Django的模塊(視圖、URL、模型、表單等)、靜態(tài)文件、數(shù)據(jù)庫遷移、管理命令、單元測試等等。您應(yīng)該使用簡單的邏輯將您的項(xiàng)目劃分為小型的、可重用的應(yīng)用程序。

使用這樣的結(jié)構(gòu),相關(guān)的功能將更緊密地結(jié)合在一起,從而允許您和您的團(tuán)隊(duì)更清楚地看到您的應(yīng)用程序的全貌。最重要的是,您可以將該應(yīng)用程序?qū)С龅搅硪粋€項(xiàng)目中并再次使用它,甚至可以將它作為一個開源模塊發(fā)布在PyPi上。

編寫健壯的視圖和骨感的模型

Django的體系結(jié)構(gòu)可以描述為一個模型-模板-視圖(MTV)或模型-視圖-模板(MVT)。

模型是大多數(shù)業(yè)務(wù)邏輯存在的地方。它被定義在models.py中,并存在于應(yīng)用程序目錄中。它還包括將結(jié)果傳遞給視圖和模板層的數(shù)據(jù)庫查詢。

視圖由處理用戶交互的代碼組成,如處理用戶提交的表單和修改數(shù)據(jù)庫中的結(jié)果以適應(yīng)您的模板。它被定義在views.py中。

如果您沒有在模型中編寫應(yīng)用程序的邏輯并使用視圖,這意味著您在基于視圖的模型中編寫了代碼。這使得視圖“健壯”,而模型“骨感”。模型應(yīng)該健壯一些,而視圖應(yīng)該骨感一些。

您還應(yīng)該利用自定義管理器。例如,自定義管理器可以提供with_counts方法,該方法會返回一個所有OpinionPoll對象的列表,每個對象都有一個額外的num_responses屬性,該屬性是聚合查詢的結(jié)果。有關(guān)更多信息,請查看內(nèi)置的UserManager。

每個視圖有太多的查詢或未優(yōu)化的查詢

人們經(jīng)常指責(zé)Django的ORM執(zhí)行了太多的查詢或未優(yōu)化的查詢。但是我們在其他框架的ORM中也能看到這種情況。

真正的問題是我們常常沒有意識到性能問題及其根源。一旦您發(fā)現(xiàn)了瓶頸所在,您就可以選擇正確的方法來解決它們。從這里你可以做很多事情,但最有可能的是:

  • 修復(fù)普通中斷的ORM查詢(比如,預(yù)取)

  • 調(diào)整和優(yōu)化ORM查詢

  • 在正確的位置添加緩存

  • 提供更多的資源

django-debug-toolbar是一個非常棒的調(diào)試工具。您可以使用它來跟蹤SQL查詢、請求、模板、緩存等等中的性能問題。這個小工具包將幫助您快速識別問題。我強(qiáng)烈推薦您使用它。

冗余的模型字段

由于查詢不能使用計(jì)算列,而且添加一個實(shí)際的列只需“進(jìn)行遷移”,因此,開發(fā)人員通常會以不同的方式復(fù)制表示相同數(shù)據(jù)的字段。

>>> 今日簽到口令:1bof <<<

很快,您的半數(shù)車輛都有is_motorcycle == True和wheel_count == 4字段,并且您不確定應(yīng)該信任哪個字段(提示:兩者都不是)。

使用Django,您可以像這樣使用@property裝飾器來重構(gòu)不一致的屬性。然而,雖然ORM允許您以屬性的形式去訪問列,但反之則不正確,因此您必須手動重構(gòu)每個查詢。

沒有在模型上添加索引

即使是經(jīng)驗(yàn)豐富的Django開發(fā)人員也會忘記索引。請務(wù)必向您的模型添加索引!另一方面,不要對所有東西都進(jìn)行索引,因?yàn)檫@會減慢插入、更新和刪除的速度。一般來說,您希望用于篩選或查詢的任何內(nèi)容都有一個索引。分析您的查詢集以確定哪里需要索引。

不一致的數(shù)據(jù)驗(yàn)證

Django模型可以與一個或多個用于創(chuàng)建和更新模型實(shí)例的“表單”相關(guān)聯(lián)。表單有很多默認(rèn)行為,特別是驗(yàn)證,這是由模型的屬性控制的。實(shí)際上,模型的許多屬性的存在只是為了控制表單的默認(rèn)行為。

許多Django開發(fā)人員忘記了模型不僅僅可以通過它的表單進(jìn)行修改。他們也忘記了跟蹤約束在哪里。非空嗎?那是模型上的。在一個字段上定義選項(xiàng),顯式枚舉它可以具有什么值?那是在表單上。唯一性嗎?在模型上。等等。

這種不一致的驗(yàn)證會導(dǎo)致糟糕的用戶體驗(yàn):預(yù)先填充了一個對象的現(xiàn)有數(shù)據(jù)的表單,會由于現(xiàn)有數(shù)據(jù)無效而無法提交。

總結(jié)

Django旨在幫助開發(fā)人員盡可能快地構(gòu)建軟件。然而,在匆忙添加新功能時,很容易會忘記一些東西或放松對全局的考慮。在本文中,我們討論了Django開發(fā)人員經(jīng)常犯的一些常見錯誤以及避免這些錯誤的方法。

即使您是一名熟練的Django開發(fā)人員,這個清單也應(yīng)該會很有用,因?yàn)橄駴]有在模型上添加索引或不一致的數(shù)據(jù)驗(yàn)證之類的錯誤,不僅僅限于新開發(fā)人員。

如果您喜歡這篇文章,那么您應(yīng)該看看《Django作為Python開發(fā)人員web框架的優(yōu)點(diǎn)和缺點(diǎn)》一文。

英文原文:https://www.softkraft.co/7-common-mistakes-that-django-developers-make/
譯者:憂郁的紅秋褲

(正文已結(jié)束)

推薦閱讀:尋找iphone在哪里

免責(zé)聲明及提醒:此文內(nèi)容為本網(wǎng)所轉(zhuǎn)載企業(yè)宣傳資訊,該相關(guān)信息僅為宣傳及傳遞更多信息之目的,不代表本網(wǎng)站觀點(diǎn),文章真實(shí)性請瀏覽者慎重核實(shí)!任何投資加盟均有風(fēng)險,提醒廣大民眾投資需謹(jǐn)慎!

網(wǎng)站簡介 - 聯(lián)系我們 - 營銷服務(wù) - 老版地圖 - 版權(quán)聲明 - 網(wǎng)站地圖
Copyright.2002-2019 寧夏資訊網(wǎng) 版權(quán)所有 本網(wǎng)拒絕一切非法行為 歡迎監(jiān)督舉報 如有錯誤信息 歡迎糾正