Django中如何使用sass的方法步驟
作為一個(gè)運(yùn)維開發(fā),不像業(yè)務(wù)開發(fā)只專注后端業(yè)務(wù)開發(fā)即可,常常需要自己來構(gòu)建前端的東西,當(dāng)然系統(tǒng)交互體驗(yàn)說的過去就行,要求也沒有業(yè)務(wù)系統(tǒng)那么高。但是還是會(huì)接觸很多前端的知識(shí),像是css、html、javascript 是必不可少的,你可以不精通,但必須會(huì)用。最近前端發(fā)展迅猛,已向著工程化大前端進(jìn)發(fā)。常常開玩笑說,前端才是全棧,前后端、各平臺(tái)全端通吃,現(xiàn)在貌似已成為事實(shí)。
今天,和大家分享下前端樣式工具 sass 如何在 Django 中應(yīng)用。
什么是 sass
Sass or (Syntactically awesome style sheets) is a preprocessor scripting language that is interpreted or compiled into Cascading Style Sheets (CSS). - Wikipedia
以上是wiki百科的解釋,簡單來說,sass 是一種方便大家來編寫css的一種高級(jí)的樣式預(yù)編譯語言。只所以叫「預(yù)編譯」,是因?yàn)槭褂盟臅r(shí)候,需要編譯成瀏覽器能識(shí)別的css。
官方網(wǎng)站: https://sass-lang.com/
Sass 3版本以后,新引入了 Scss 語法,它完全兼容 Css3 ,并且繼承了 Sass 的強(qiáng)大功能。關(guān)于 Scss 和 Sass ,這里不做過多解釋,有興趣的可參考官方文檔介紹。
話說回來, Sass 除了編寫方便外,還有那些優(yōu)勢,大家可閱讀這篇經(jīng)典的文章 why sass? 。
下面,來說下怎么在我們的常用web框架 Django 中如何集成。
在Django中使用sass
下面我們來一步步的配置 Sass 。環(huán)境如下:
- Python:3.6
- Django: 2.2
創(chuàng)建Django項(xiàng)目
1、創(chuàng)建Python的開發(fā)虛擬環(huán)境:
$ python3 -m venv env $ source env/bin/active
2、安裝 django , 創(chuàng)建 django 項(xiàng)目;
$ pip install django $ django-admin startproject sass_demo
3、增加相關(guān)配置
# settings.py TEMPLATES = [ { ... 'DIRS': [ os.path.join(BASE_DIR, 'templates') ], } ... ]
并創(chuàng)建一個(gè) index.html 模板,如下:
<html> <head> <title>Django sass demo</title> </head> <body> <div class="content"> Django sass demo </div> </body> </html>
運(yùn)行 python manaage.py runserver 檢查Django項(xiàng)目是否配置好。
安裝Django sass
這里我們采用了兩個(gè)Django的第三方應(yīng)用 django-compressor 和 django-sass-processor , 分別對 css 進(jìn)行壓縮和編譯。
1、安裝django sass 應(yīng)用庫
$ pip install libsass django-compressor django-sass-processor
2、settings 中增加如下配置
INSTALLED_APPS = [ … 'sass_processor', … ] STATICFILES_FINDERS = [ 'django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder', 'sass_processor.finders.CssFinder', ] # Django Sass 編譯后css 的存放位置 SASS_PROCESSOR_ROOT = os.path.join(BASE_DIR,'static','css')
3、添加sass文件
創(chuàng)建sass 文件。
$ mkdir static && touch static/css/demo.scss
在 index.html 中加入如下配置:
{% load sass_tags %} <html> <head> <title>Django sass demo</title> <link href="{% sass_src 'css/demo.scss' %}" rel="external nofollow" rel="stylesheet" type="text/css" /> </head> <body> <div class="content"> Django sass demo </div> </body> </html>
demo.scss 添加sass 的樣式代碼:
body { .content{ width: 100%; padding: 20px; text-align: center; background: grey; p { padding: 20px; background: pink; } } }
在瀏覽器,再次刷新會(huì)看到樣式生效。打開開發(fā)者工具,查看html代碼,會(huì)發(fā)現(xiàn),sass代碼已替換為css,如下:
<link href="/static/css/demo.css" rel="external nofollow" rel="stylesheet" type="text/css">
至此,整個(gè)Sass 的集成工作就完成了。
總結(jié)
django-compressor 和 django-sass-processor 很好的完成了css的編譯和壓縮工作,上文只是簡單快速的描述了下配置的過程,還有更多功能大家可參閱他們的使用文檔。另外他們的壓縮功能是根據(jù) Debug 來控制的,只有生產(chǎn)環(huán)境,即 Debug 為false 的時(shí)候才會(huì)壓縮。測試環(huán)境中,可通過添加如下參數(shù)嘗試:
SASS_OUTPUT_STYLE = 'compressed'
以上代碼的完整版本,可從這里獲?。?nbsp;https://github.com/pylixm/django-sass-demo
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python函數(shù)基礎(chǔ)(定義函數(shù)、函數(shù)參數(shù)、匿名函數(shù))
這篇文章介紹了Python函數(shù)的基礎(chǔ)用法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-05-05將python flask項(xiàng)目打包成可以運(yùn)行的軟件的全過程(包含報(bào)錯(cuò)解決)
這篇文章主要給大家介紹了將python flask項(xiàng)目打包成可以用運(yùn)行的軟件(包含報(bào)錯(cuò)解決),文中通過代碼示例和圖文結(jié)合講解的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下2024-02-02flask框架實(shí)現(xiàn)連接sqlite3數(shù)據(jù)庫的方法分析
這篇文章主要介紹了flask框架實(shí)現(xiàn)連接sqlite3數(shù)據(jù)庫的方法,結(jié)合實(shí)例形式分析了flask框架連接sqlite3數(shù)據(jù)庫的具體操作步驟與相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-07-07深入理解Python虛擬機(jī)中復(fù)數(shù)(complex)的實(shí)現(xiàn)原理及源碼剖析
在本篇文章當(dāng)中主要給大家介紹在 cpython 虛擬機(jī)當(dāng)中是如何實(shí)現(xiàn) 復(fù)數(shù) complex 這個(gè)數(shù)據(jù)類型的,這個(gè)數(shù)據(jù)類型在 cpython 當(dāng)中一應(yīng)該是一個(gè)算比較簡單的數(shù)據(jù)類型了,非常容易理解2023-03-03淺談keras.callbacks設(shè)置模型保存策略
這篇文章主要介紹了淺談keras.callbacks設(shè)置模型保存策略,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06