摘要:今天這篇主要講講里關(guān)于樣式開(kāi)發(fā)的一些前期準(zhǔn)備工作,主要是和??偟膩?lái)說(shuō)就不要再用了,又大又笨而且連親爹都準(zhǔn)備放棄它了,未來(lái)將是小快靈組件協(xié)同工作的大趨勢(shì),就是可以用來(lái)替代的組件庫(kù)。
今天這篇主要講講 Ember CLI 里關(guān)于樣式開(kāi)發(fā)的一些前期準(zhǔn)備工作,主要是 Sass 和 Bootstrap。
關(guān)于 SassEmber Addons 是尋找各種組件的絕佳場(chǎng)所,下文將要介紹的一些都可以在這里找到,沒(méi)事的時(shí)候多探索一下會(huì)有很多驚喜。
Sass 的演變和使用在前端開(kāi)發(fā)領(lǐng)域真是個(gè)又臭又長(zhǎng)的話題,如果你是自行搭建構(gòu)建系統(tǒng)你就明白我說(shuō)的意思了。還好 Ember CLI 的生態(tài)系統(tǒng)比較完備,也有一個(gè)廣大的社區(qū)做后盾可以為我們省去很多功夫。
對(duì)于 Sass 的基礎(chǔ)使用,我們只需要安裝 |3822741913b0abccece813de6916a2f41| 就好了,它默認(rèn)使用 node-sass,支持 SourceMaps 和 IncludePaths 等功能選項(xiàng),比較省心。較新的 Ember CLI 應(yīng)該是直接內(nèi)置了 ember-cli-sass 的,推薦升級(jí)哦。
對(duì)于不太熟悉 Sass 的程序員,IncludePaths 值得一講,我見(jiàn)到有些人啊為了方便的 import,把許多第三方的 sass 文件拷過(guò)來(lái)拷過(guò)去的,其實(shí)大可不必哦~就拿 bootstrap-sass 為例好了:
安裝 bootstrap-sass:
$ npm install bootstrap-sass --save
完后呢,入口文件的路徑在 node_modules/bootstrap-sass/assets/stylesheets 這里,因?yàn)橥ǔ?node_modules/ 和 bower_components/ 這些目錄是不會(huì)被包含在項(xiàng)目里的(包含在 Git 或 HTTP Server Root 下),所以才會(huì)有手工拷貝到別處的做法。在 Ember CLI 里,你可以這樣設(shè)置一下:
// ember-cli-build.js or Brocfile.js var app = new EmberApp(defaults, { sassOptions: { includePaths: [ "node_modules/bootstrap-sass/assets/stylesheets" ] } })
之后在項(xiàng)目的 sass 文件內(nèi)直接 @import "bootstrap"; 就好了,那是一個(gè)數(shù)組所以你懂的,你可以設(shè)置很多路徑,sass 在編譯的時(shí)候會(huì)挨個(gè)兒去找。
關(guān)于 POD如果你跟我一樣喜歡 POD 文件結(jié)構(gòu),那么還有一個(gè) ember-cli-sass-pods 也可以用用,這個(gè)東西能讓你這樣生成 sass 文件:
$ ember generate style [name] -p
生成的文件會(huì)保存在同名的 POD 目錄下,不過(guò)我一向都是手動(dòng)創(chuàng)建文件的,所以并沒(méi)有實(shí)際測(cè)試它。對(duì)于樣式文件在 POD 架構(gòu)下的導(dǎo)入我是這樣做的:
創(chuàng)建 app/styles/_pods.scss 文件
在 app/styles/app.scss 文件里添加一句 @import "pods";
在 includePaths 那里添加 app/pods 這一項(xiàng)
新增加的 PODs 樣式在 app/styles/_pods.scss 內(nèi)這樣引用:`@import "name/style;"
后來(lái)我注意到 ember-cli-sass-pods 也是這么做的,英雄所見(jiàn)略同嘛~
關(guān)于 Bootstrap w/ sass前面提到了用 |3822741913b0abccece813de6916a2f415| 來(lái)引用 Bootstrap 的方法,不過(guò)在 Ember CLI 項(xiàng)目里,我還是推薦你用 ember-cli-bootstrap-sassy 來(lái)輔助你做這件事,因?yàn)檫@個(gè) addon 額外做了幾件好事:
添加了 bower 版的 bootstrap-sass,省去了你人工尋找和安裝的過(guò)程
完成了 includePaths 的設(shè)置,免得你忘記了
完成了 |3822741913b0abccece813de6916a2f420| 和 腳本文件的導(dǎo)入,好省心吶
Bootstrap 自帶的字體圖標(biāo)可以選擇不導(dǎo)入,JavaScript 的模塊可以選擇性的導(dǎo)入或者完全不要,具體設(shè)置如下所示:
var app = new EmberApp(defaults, { // ... "ember-cli-bootstrap-sassy": { glyphicons: false, js: ["transition", "collapse"] } })使用/定制 Bootstrap 的正確姿勢(shì)
關(guān)于這個(gè)話題我簡(jiǎn)直可以寫(xiě)本小說(shuō)出來(lái)了,在我?guī)?shí)習(xí)生的過(guò)程里被問(wèn)到和發(fā)現(xiàn)最多問(wèn)題的就是 Bootstrap 的用法,限于篇幅我在這里只將一些前期的要點(diǎn):
別直接用 _bootstrap.scss大多數(shù)人是這樣用的:直接在主樣式文件里 @import "bootstrap";,然后遇到需要定制的就開(kāi)始覆蓋覆蓋覆蓋……別這么搞!
看一下 |3822741913b0abccece813de6916a2f424| 以及 源碼 便知道人家本來(lái)就是模塊化開(kāi)發(fā)的,既然用了 sass 咱就應(yīng)該把它當(dāng)成級(jí)別高點(diǎn)的編程語(yǔ)言來(lái)對(duì)待。我是這么做的:
創(chuàng)建 app/styles/_custom-bootstrap.scss 文件
在 app/styles/app.scss 里 @import "custom-bootstrap";,一般來(lái)說(shuō)這個(gè)應(yīng)該是第一個(gè)導(dǎo)入的模塊
一開(kāi)始你可以把原來(lái)的 _bootstrap.scss 內(nèi)容原封不動(dòng)拷貝進(jìn)來(lái),由于 includePaths 的作用,所有導(dǎo)入的路徑都可以不變。
然后把所有的模塊導(dǎo)入都注釋掉,此時(shí)你的項(xiàng)目里等于完全沒(méi)有 Bootstrap。
之后一般會(huì)分兩種情況來(lái)定制:
需要用到且可以直接沿用的模塊
這個(gè)簡(jiǎn)單,把注釋的部分去掉就好了嘛。曾經(jīng)有徒弟質(zhì)疑我:“師傅,人家官網(wǎng)上有自定義模塊構(gòu)建的功能,咱為啥不用那個(gè)?”
圖樣圖森破,那個(gè)功能就是拿來(lái)秀的,一點(diǎn)實(shí)用性都沒(méi)有。有多少人自定義構(gòu)建之后從頭用到尾剛剛好既不多又不少的?神都預(yù)測(cè)不到你會(huì)用到哪些組件的,難道你一遍又一遍的去構(gòu)建定制版本啊?那是菜鳥(niǎo)的用法。
需要用到但得修改/定制的模塊
這里又可以大致分出兩種情形,比較簡(jiǎn)單的改動(dòng)——比如變量,你可以把其定義寫(xiě)在 @import "bootstrap/variables"; 的前面(特別是覆蓋默認(rèn)變量的,一定注意順序);我會(huì)做的比較徹底,直接創(chuàng)建一個(gè) app/styles/_custom-variables.scss 并且作為第一個(gè)模塊導(dǎo)入進(jìn)去。另外,自定義的變量不需要寫(xiě)尾部的 !default。
第二種情形就比較進(jìn)階一些了,我舉個(gè)例子,以前經(jīng)??匆?jiàn)這樣的寫(xiě)法:
我說(shuō)你寫(xiě)這么多 class 不累啊?人家 Bootstrap 是為了可重用性才定義了這種粒度很細(xì)的 helper classes,如果你是做一個(gè) rapid prototype 那我沒(méi)意見(jiàn),但是正式的產(chǎn)品這樣寫(xiě)問(wèn)題就大了:
像 btn-purple 這樣的命名是很糟糕的,完全沒(méi)有語(yǔ)義性,萬(wàn)一將來(lái)要換個(gè)色彩主題怎么辦?可維護(hù)性也很差,萬(wàn)一將來(lái)維護(hù)的是個(gè)色盲怎么辦?(開(kāi)個(gè)玩笑)
重復(fù)的寫(xiě)一串 class 可讀性也很差,如果將來(lái)要進(jìn)行微調(diào),不熟悉這些 class 的人會(huì)被折騰死
該怎么寫(xiě)?
/// app/styles/_custom-buttons.scss // Overwrite for more semantic button class names .button { @extend .btn; // Bootstrap doesn"t give buttons transition effects by default, // so we simply extend it here. You can use some mixin instead. transition: all .2s ease-out; } @each $name in default, primary, success, warning, danger, info, block { .button-#{$name} { @extend .btn-#{$name}; } } // Define site-wide main button colors $button-main-color: #fff; $button-main-bg: $violet; $button-main-border: darken($violet, 5%); .button-main { @extend .button; @include button-variant( $button-main-color, $button-main-bg, $button-main-border ); }
這是個(gè)例子,我從最近的一個(gè)項(xiàng)目里扒出來(lái)的,僅就這一例子而言或許有點(diǎn)小題大做,但如果考慮一個(gè)大型的項(xiàng)目,這樣的改造絕對(duì)是有必要的。好的習(xí)慣要從小養(yǎng)成,正確的姿勢(shì)得貫徹始終。
類似的技巧還有好多,鑒于這里的主題是 Ember CLI 呢便就此打住了,我也是想:既然選擇了 Ember 這么靠譜的前端框架,相應(yīng)的前端技術(shù)也應(yīng)該靠譜起來(lái)吧,所以拋磚引玉一下。
還有什么值得一用?Bootstrap 絕對(duì)不完美,只會(huì)用它的前端工程師絕對(duì)不是合格的前端工程師,針對(duì) Bootstrap 不完善的地方 sass 社區(qū)還有非常多的組件值得一用。在這里我先推薦幾個(gè),以后還可以再補(bǔ)充。
SusyBootstrap 的 Grid 系統(tǒng)很一般(雖說(shuō)對(duì)它的定位而言也夠用),定死的 12 柵格并非時(shí)時(shí)夠用;嵌套時(shí)的 gutter 無(wú)法靈活調(diào)整;需要手動(dòng)覆蓋 row 兩端 cols 的 padding(當(dāng)你需要邊緣與 container 對(duì)齊的時(shí)候,如 gallery 布局)……等等槽點(diǎn)都被噴了好幾年了。
Bootstrap v4 將使用 flex 做 Grid 系統(tǒng),這是好事
所以我推薦你試一下 Susy,做布局——專業(yè)的!用在 Ember CLI 里也很簡(jiǎn)單,|3822741913b0abccece813de6916a2f436|,然后設(shè)定一下 |3822741913b0abccece813de6916a2f437| 就好,非常輕量,非常好用
BourbonBootstrap 自己定義了一些 |3822741913b0abccece813de6916a2f439| 善用它們會(huì)令你事半功倍,然而習(xí)慣了 compass 的開(kāi)發(fā)者大概還是會(huì)覺(jué)得不夠用吧?因此我向你推薦 Bourbon,ThoughtBot 出品,Ruby 社區(qū)應(yīng)該不陌生的,品質(zhì)一流。
總的來(lái)說(shuō) Compass 就不要再用了,又大又笨而且連親爹都準(zhǔn)備放棄它了,未來(lái)將是小快靈組件協(xié)同工作的大趨勢(shì),Bourbon 就是可以用來(lái)替代 |3822741913b0abccece813de6916a2f441| 的組件庫(kù)。另外它的兄弟 Neat 也不錯(cuò),只是功能上和我們上述的工具集合有沖突了,不是很有必要。
Breakpoint這個(gè)推薦一下,可以選用,主要是用來(lái)輔助響應(yīng)式設(shè)計(jì)開(kāi)發(fā)的,比 Bootstrap 自帶的那點(diǎn)特性強(qiáng)大多了。http://breakpoint-sass.com/
關(guān)于后期處理前面說(shuō)的一大堆綜合起來(lái)都是做 CSS 的前期處理的(也就是 pre-processing),現(xiàn)在前端也很重視后期處理(post-processing),關(guān)于這個(gè)話題呢推薦看一下 pleeease 也就差不多了。
樣式的后期處理有很多范疇,綜合考慮我認(rèn)為目前唯一稱得上必須要做的那就是 Autoprefixer,這個(gè)東西的特點(diǎn)及用法概括如下:
有了它,你再也不用去寫(xiě) vendor prefixes,連想都不要去想(如果你用到的第三方組件越俎代庖了也沒(méi)關(guān)系,Autoprefixer 會(huì)自動(dòng)篩選一遍)
當(dāng)你構(gòu)建的時(shí)候,它會(huì)自動(dòng)分析你的樣式,然后添加必要的 vendor prefixes
你可以指定針對(duì)的瀏覽器品牌,版本,受眾地區(qū)等等參量,從而讓它知道哪些 vendor prefixes 是需要加的
它通過(guò) Can I Use 提供的技術(shù)數(shù)據(jù)來(lái)完成最終的工作
ember-cli-autoprefixer 可以幫助你把它集成到 Ember CLI 項(xiàng)目中,簡(jiǎn)單好用。以下是一個(gè)配置的范例代碼:
var app = new EmberApp(defaults, { // ... autoprefixer: { browsers: ["> 5% in CN", "last 2 versions"] } })
仔細(xì)閱讀一下 Autoprefixer 的文檔,你會(huì)發(fā)現(xiàn)配置它所用到的 DSL(BrowserList) 還蠻有趣的。
得,今天就說(shuō)到這里,本來(lái)這篇早就寫(xiě)得差不多了,只是這兩天一直在挖/填 Ember2 的一些坑沒(méi)顧上整理,耽誤了。到此前期的周邊打造就差不多了,下篇開(kāi)始我打算重點(diǎn)寫(xiě)一些和 Ember 的特性密切相關(guān)的東東,maybe 先從路由開(kāi)始。
原文首發(fā)于 Ruby China 社區(qū),轉(zhuǎn)載請(qǐng)注明。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/85963.html
摘要:警告版本是很不穩(wěn)定的,并不推薦使用于要上線的應(yīng)用。如果你要嘗試新的特性,要么是新建一個(gè)測(cè)試用的,要么是你的應(yīng)用離正式上線還早并且你和你的團(tuán)隊(duì)折騰得起。在此功能正式發(fā)布之后應(yīng)該是不需要這段補(bǔ)丁代碼的,目前來(lái)說(shuō)也不會(huì)影響使用。 Ruby China 的朋友大概都知道我很喜歡 Ember,然而我用 Ember 的經(jīng)歷其實(shí)遠(yuǎn)比不上 Angular 那么豐富(Ember 業(yè)余愛(ài)好,Angular...
摘要:好,你用就用吧,各種問(wèn)題自己也不會(huì)看文檔問(wèn)谷歌,成天怨聲載道的不得不吐槽一下現(xiàn)在的年輕人。為什么使用有關(guān)和的糾結(jié)歷史可以去谷歌一下,此處不再啰嗦最根本的原因就是對(duì)的支持更好,更新和維護(hù)也更勤快。 Tips on Ember 2 對(duì)我來(lái)說(shuō)是沒(méi)什么計(jì)劃性的寫(xiě)作,我只是把它當(dāng)做是每天工作的總結(jié)日志,一個(gè)很重要的目的是為團(tuán)隊(duì)做一些技術(shù)事務(wù)的整理,以幫助一些新人快速成長(zhǎng)起來(lái)。如果有些內(nèi)容不能滿足...
摘要:原文環(huán)境搭建以及使用創(chuàng)建第一個(gè)靜態(tài)頁(yè)面本篇將為讀者介紹項(xiàng)目開(kāi)發(fā)環(huán)境的搭建,并創(chuàng)建一個(gè)靜態(tài)頁(yè)面。在文件中增加如下內(nèi)容使用快捷鍵關(guān)閉在用命令啟動(dòng)項(xiàng)目。創(chuàng)建一個(gè)模板仍然是使用命令創(chuàng)建模板。 原文:環(huán)境搭建以及使用Ember.js創(chuàng)建第一個(gè)靜態(tài)頁(yè)面 本篇將為讀者介紹Ember項(xiàng)目開(kāi)發(fā)環(huán)境的搭建,并創(chuàng)建一個(gè)靜態(tài)頁(yè)面。 安裝Ember CLI 本教程使用的是2.4.3版本的Ember CLI工具集...
摘要:因?yàn)榻M件的存在范圍被限制在以內(nèi),這就是這種機(jī)制目前存在的意義所在。組件都是可以傳遞參數(shù)或外部作用域的,利用此機(jī)制進(jìn)行判斷來(lái)執(zhí)行可選行為,這是對(duì)用戶友好的舉措。 這一篇還是一個(gè)簡(jiǎn)單的例子所引發(fā)的思考。 你看,如今的框架和庫(kù),無(wú)論規(guī)模大小功能多少,它們?cè)诒举|(zhì)上都朝著組件化的思路快速演進(jìn)著。Angular 有 directives,Angular 2應(yīng)該也還是這個(gè)叫法;Ember 從 Vie...
摘要:初始化一個(gè)新的項(xiàng)目生成項(xiàng)目其中用于跳過(guò)初始化項(xiàng)目時(shí)自帶的組件。是在初始化完成之后,就進(jìn)行依賴的安裝。在命令行中運(yùn)行之后,打開(kāi)之,就能看到這就說(shuō)明的項(xiàng)目已經(jīng)成功啟動(dòng)。自動(dòng)引入依賴包數(shù)據(jù)至此,項(xiàng)目的整個(gè)過(guò)程就結(jié)束了。 Ember Guide 1. 初始化一個(gè)新的項(xiàng)目 1.1 生成項(xiàng)目 ember new ember-guide --no-welcome --yarn 其中--no-wel...
閱讀 799·2021-10-09 09:44
閱讀 704·2019-08-30 13:55
閱讀 3162·2019-08-29 15:07
閱讀 3228·2019-08-29 13:09
閱讀 2420·2019-08-29 11:10
閱讀 1297·2019-08-26 14:05
閱讀 3604·2019-08-26 13:57
閱讀 2212·2019-08-23 16:42