成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專(zhuān)欄INFORMATION COLUMN

使用 Nginx 編譯 Sass 和 Scss

y1chuan / 871人閱讀

摘要:前端的小伙伴對(duì)于或以下統(tǒng)稱(chēng)應(yīng)該并不陌生,他是一種預(yù)處理語(yǔ)言,使用可以極大簡(jiǎn)化代碼的編寫(xiě)和維護(hù)。通常情況下,我們?cè)陂_(kāi)發(fā)環(huán)境下使用是在或者環(huán)境下,通過(guò)監(jiān)聽(tīng)文件修改來(lái)實(shí)時(shí)編譯并輸出到瀏覽器。

前端的小伙伴對(duì)于 Sass 或 Scss(以下統(tǒng)稱(chēng) Sass) 應(yīng)該并不陌生,他是一種 CSS 預(yù)處理語(yǔ)言,使用 Sass 可以極大簡(jiǎn)化 CSS 代碼的編寫(xiě)和維護(hù)。

通常情況下,我們?cè)?strong>開(kāi)發(fā)環(huán)境下使用 Sass 是在 webpack dev server 或者 Gulp 環(huán)境下,通過(guò)監(jiān)聽(tīng)文件修改來(lái)實(shí)時(shí)編譯 Sass 并輸出 CSS 到瀏覽器。接下來(lái),我想給大家介紹一種獨(dú)辟蹊徑的方式,那就是在開(kāi)發(fā)環(huán)境下通過(guò) Nginx 編譯 Sass 并實(shí)時(shí)輸出 CSS 到瀏覽器的方法。

下面簡(jiǎn)單介紹一下如何搭建環(huán)境:(如不想自己配置環(huán)境,文末提供了一個(gè) Docker 鏡像,可以一鍵搭建環(huán)境)

Nginx 設(shè)置

為了支持 Sass 的編譯,我們需要 Nginx Lua module,也就是 openresty,安裝方法可以參考官網(wǎng): https://openresty.org/cn/inst... 或 https://github.com/openresty/... 。Ubuntu 系統(tǒng)可以直接通過(guò) apt 包管理安裝: apt install nginx libnginx-mod-http-lua

確保 Lua 模塊安裝好以后,我們還需要一些處理 Sass 的 Lua 腳本,可以從這里下載: https://github.com/hex-ci/doc... ,把代碼解壓縮到目錄下,例如: /your/path/lua,然后我們來(lái)配置 nginx.conf:

http {
    # 其它配置....

    lua_package_path "/your/path/lua/?.lua;;";

    # 其它配置.....

    server {
        # 其它配置...

        location / {
            header_filter_by_lua_block {
                ngx.header.content_length = nil
                ngx.header.content_encoding = ""
            }

            body_filter_by_lua_file /your/path/lua/body.lua;

            try_files $uri $uri/ =404;
        }

        location ~ .php$ {
            # 其它配置...

            header_filter_by_lua_block {
                ngx.header.content_length = nil
                ngx.header.content_encoding = ""
            }

            body_filter_by_lua_file /your/path/lua/body.lua;
        }

        location ~ ^.*.scss$ {
            set $sass_output_style            expanded;
            set $sass_source_map_embed        on;
            set $sass_source_map_contents     on;
            set $sass_is_indented_syntax_src  off;

            content_by_lua_file /your/path/lua/resty/sass/autocompile.lua;
        }

        location ~ ^.*.sass$ {
            set $sass_output_style            expanded;
            set $sass_source_map_embed        on;
            set $sass_source_map_contents     on;
            set $sass_is_indented_syntax_src  on;

            content_by_lua_file /your/path/lua/resty/sass/autocompile.lua;
        }

        # 其它配置...
    }
}
安裝依賴(lài)

編譯 Sass 還需要系統(tǒng)安裝 libsass 和 lua-zlib,在 Ubuntu 下可以通過(guò) apt 安裝: apt install libsass-dev lua-zlib-dev

如需自己編譯請(qǐng)參考 https://github.com/sass/libsass 和 https://github.com/brimworks/...

使用

經(jīng)過(guò)以上配置,Nginx 將支持 .scss 和 .sass 文件的實(shí)時(shí)編譯,也支持 .html、.php 等內(nèi)聯(lián) Sass 的編譯,例如:

Docker 鏡像

為便于環(huán)境的搭建,制作了一個(gè) Docker 鏡像,可以很方便的搭建支持 Sass 的 Nginx。

鏡像 github: https://github.com/hex-ci/doc...

啟動(dòng)容器:docker run --name your-name -v /your/html/path:/usr/share/nginx/html -p your-port:80 -d codeigniter/nginx-lua-sass:3

使用自定義配置啟動(dòng)容器: docker run --name your-name -v /your/html/path:/usr/share/nginx/html -v /your/path/default.conf:/etc/nginx/conf.d/default.conf -p your-port:80 -d codeigniter/nginx-lua-sass:3

最后,歡迎與大家多多交流有意思的技術(shù)~謝謝~

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/39914.html

相關(guān)文章

  • 使用 Nginx 編譯 Sass Scss

    摘要:前端的小伙伴對(duì)于或以下統(tǒng)稱(chēng)應(yīng)該并不陌生,他是一種預(yù)處理語(yǔ)言,使用可以極大簡(jiǎn)化代碼的編寫(xiě)和維護(hù)。通常情況下,我們?cè)陂_(kāi)發(fā)環(huán)境下使用是在或者環(huán)境下,通過(guò)監(jiān)聽(tīng)文件修改來(lái)實(shí)時(shí)編譯并輸出到瀏覽器。 前端的小伙伴對(duì)于 Sass 或 Scss(以下統(tǒng)稱(chēng) Sass) 應(yīng)該并不陌生,他是一種 CSS 預(yù)處理語(yǔ)言,使用 Sass 可以極大簡(jiǎn)化 CSS 代碼的編寫(xiě)和維護(hù)。 通常情況下,我們?cè)陂_(kāi)發(fā)環(huán)境下使用 S...

    ACb0y 評(píng)論0 收藏0
  • Mac系統(tǒng)使用VS Code編譯Bootstrap 4

    摘要:使用,已改為使用,所以首先解決編譯問(wèn)題。編譯與無(wú)關(guān),需要在系統(tǒng)中安裝編譯環(huán)境。使用編譯源碼結(jié)構(gòu)簡(jiǎn)單分析源碼,其中文件夾包含了所有樣式文件源碼,部件和工具都是單獨(dú)的文件,很清晰。可以看到命令已成功運(yùn)行,及文件已經(jīng)生成。 環(huán)境: macOS 10.13.6 node.js 8.11.3 sass 1.10.3 bootstrap 4.1.3 vs code 1.25.1 ...

    simpleapples 評(píng)論0 收藏0
  • CSS 強(qiáng)化裝備!Sass 安裝與使用

    摘要:不過(guò)必須要先安裝,然后再安裝。淘寶鏡像安裝由于國(guó)內(nèi)網(wǎng)絡(luò)原因你懂的,導(dǎo)致存放在上面的資源文件間歇性連接失敗。嵌套可以進(jìn)行選擇器的嵌套,表示層級(jí)關(guān)系。重要注釋管理項(xiàng)目文件結(jié)構(gòu)預(yù)處理器的特點(diǎn)之一是可以把你的代碼分割成很多文件,而且不會(huì)影響性能。 Sass 是什么? showImg(https://segmentfault.com/img/bVqyKF); Sass 是 Syntactical...

    wuyumin 評(píng)論0 收藏0
  • vue入門(mén)文章

    摘要:本來(lái)想自己寫(xiě)一篇關(guān)于入門(mén)的文章。后面可能在這篇文章基礎(chǔ)上,有所內(nèi)容的增加。預(yù)處理器定義了一種新的專(zhuān)門(mén)的編程語(yǔ)言,編譯后成正常的文件。 本來(lái)想自己寫(xiě)一篇關(guān)于vue入門(mén)的文章。但是看到鏈接的文章后,覺(jué)得寫(xiě)得太詳細(xì)了,實(shí)在有保存下來(lái)的必要。后面可能在這篇文章基礎(chǔ)上,有所內(nèi)容的增加。 CSS預(yù)處理器 定義了一種新的專(zhuān)門(mén)的編程語(yǔ)言,編譯后成正常的CSS文件。為CSS增加一些編程的特性,無(wú)需考慮瀏...

    seanHai 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<