2017-11-25 305 views
0

我自定義Bootstrap4,但發現很難理解爲什麼事情不按預期工作。

導入原始_variables.scss並更改$font-size-base應該工作,否則我們需要將其更改爲14個變量(例如$h1-font-size: $font-size-base * 2.5)。並且在將來當我更新我的「node_modules> bootstrap」時,那麼我不必再檢查$ font-size-base是否已經被bootstrap團隊引用到任何新變量中。

我創建和新_custom-variable.scss和進口變量的原因:

@import '../node_modules/bootstrap/scss/variables'; 

,改變$font-size-base: 1rem$font-size-base: 0.875rem;

這工作得很好,當我看到編譯CSS的body

// ../node_modules/bootstrap/scss/_reboot.scss 
body { 
    ... 
    font-size: $font-size-base; 
    ... 
} 

// compiled css 
body { 
    ... 
    font-size: 0.875rem; 
    ... 
} 

但這是問題,它不適用於標題標籤:

// In my _custom-variable.scss, when I change $font-size-base from 1rem to 0.875 
// then I expect the values changed to: 
h1 { font-size: 2.1875rem } 
h2 { font-size: 1.75rem } 
... 
h6 { font-size: .875rem } 

// but nothing gets changed 
h1 { font-size: 2.5rem } 
h2 { font-size: 2rem } 
... 
h6 { font-size: 1rem } 

我不知道這個,但我覺得這是由於計算這裏:

//../node_modules/bootstrap/scss/_variables.scss 
$h1-font-size: $font-size-base * 2.5 !default; 
$h2-font-size: $font-size-base * 2 !default; 
... 
$h6-font-size: $font-size-base !default; 
+0

在你的例子中,它的工作原理是顯示font-weight而不是font-size-base – ztadic91

+0

@ ztadic91謝謝你讓我知道,這只是我的問題中的錯字,我改變了它。 – Syed

回答

0

正如你覆蓋$font-size-base變量在_custom-variable.scss你應該overwitre的$h1-font-size$h2-font-size等...變量也在_custom-variable.scss文件中。

標題大小在_variables.scss中定義,其中$font-size-base的值仍然是原始大小。一個scss變量會保留它的原始值,直到你將它覆蓋。

另一種選擇是在原始_variables.scss文件中進行自定義。也許將默認值留在註釋塊中。

+0

感謝您的幫助。我同意你的意見,並已經做了你的建議。 node_modules不應該改變,而是導入它並覆蓋。導入原始'_variables.scss'並更改'$ font-size-base'應該可以工作,否則我需要在14個變量中改變它(例如'$ h1-font-size:$ font-size-base * 2.5')。在將來當我更新node_modules> bootstrap時,我不必再檢查是否在任何新變量中引用了'$ font-size-base'。 – Syed