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

資訊專欄INFORMATION COLUMN

Bootstrap3.x - 源代碼分析

Anchorer / 2098人閱讀

摘要:參照文檔與源代碼比較全面定義總結(jié)有意義的顏色。柵格系統(tǒng)最核心的就是柵格系統(tǒng)。創(chuàng)造了類的樣式。添加列偏移列排序,計(jì)算各個(gè)的寬度最后是調(diào)用在里包含了以上是看源碼的初步理解與感悟,都是自己感覺重要與技巧的總結(jié)如有不足之處請(qǐng)多多指教。

參照http://v3.bootcss.com/css/ 文檔與源代碼

colors

比較全面定義總結(jié)有意義的顏色。所有uI要用的顏色,都先從已定義的讀,這樣保證樣式的同一性,而且方便以后開發(fā)主題庫(kù)。(建議想自己寫css模塊的,可以參考一下bootstrap里顏色定義)

語義顏色(四鐘顏色)
有含義的顏色,當(dāng)然也可以不止這四種,如:disabled、empty

@brand-success:         #5cb85c; // 成功顏色
@brand-info:            #5bc0de; // 信息顏色
@brand-warning:         #f0ad4e; // 警告顏色
@brand-danger:          #d9534f; // 危險(xiǎn)顏色

灰度顏色
主要包含文本、文字、背景色等。

@gray-base:              #000;   // 基本的灰度
@gray-darker:            lighten(@gray-base, 13.5%); // #222
@gray-dark:              lighten(@gray-base, 20%);   // #333
@gray:                   lighten(@gray-base, 33.5%); // #555
@gray-light:             lighten(@gray-base, 46.7%); // #777
@gray-lighter:           lighten(@gray-base, 93.5%); // #eee

文字、背景色、鏈接狀態(tài)

@body-bg:               #fff;
@text-color:            @gray-dark;
@link-color:            @brand-primary;
@link-hover-color:      darken(@link-color, 15%);
@link-hover-decoration: underline;
字體

字體大小必須是在已有基礎(chǔ)上,做計(jì)算。從h1~h4間隔都是6px;h5~h6分別是14px、12px;而14是基礎(chǔ)字體

@font-family-sans-serif:  "Helvetica Neue", Helvetica, Arial, sans-serif;
@font-family-serif:       Georgia, "Times New Roman", Times, serif;
@font-family-monospace:   Menlo, Monaco, Consolas, "Courier New", monospace;
@font-family-base:        @font-family-sans-serif;

@font-size-base:          14px;
@font-size-large:         ceil((@font-size-base * 1.25)); // ~18px
@font-size-small:         ceil((@font-size-base * 0.85)); // ~12px

@font-size-h1:            floor((@font-size-base * 2.6)); // ~36px
@font-size-h2:            floor((@font-size-base * 2.15)); // ~30px
@font-size-h3:            ceil((@font-size-base * 1.7)); // ~24px
@font-size-h4:            ceil((@font-size-base * 1.25)); // ~18px
@font-size-h5:            @font-size-base;
@font-size-h6:            ceil((@font-size-base * 0.85)); // ~12px
行高

但是它不僅局限在行高上,可以推算出高度,已知字體大小與行高時(shí)
如:@line-height-computed: floor((@font-size-base * @line-height-base));//20px
一些通用的組件屬性都需要這個(gè)值,margin、padding、top、height、line-height...
所以定義好字體大小與行高的重要性不言而喻了吧。

//"line-height" for use in components like buttons.
@line-height-base:        1.428571429; // 20/14
padding與border-radius

bootstrap 有關(guān)尺寸命名的格式"-xs-" 有四種尺寸: xs、small、base、large。
而上下、左右的是:-vertical-、-horizontal-

@padding-base-vertical:     6px;
@padding-base-horizontal:   12px;

@padding-large-vertical:    10px;
@padding-large-horizontal:  16px;

@padding-small-vertical:    5px;
@padding-small-horizontal:  10px;

@padding-xs-vertical:       1px;
@padding-xs-horizontal:     5px;

@line-height-large:         1.33;
@line-height-small:         1.5;

@border-radius-base:        4px;
@border-radius-large:       6px;
@border-radius-small:       3px;
Z-index

有時(shí)關(guān)于設(shè)置z-index時(shí),我們會(huì)亂掉,只要不遮蓋就行,但是有問題時(shí),難修改、難排查;一般我們uI上有bug,會(huì)先從js上排查,最后才到css;即使找到了,發(fā)現(xiàn)需要一層一層的往父級(jí)找。因此可以在最初時(shí)寫的時(shí)候避免它,先定義好,再使用。

@zindex-navbar:            1000;
@zindex-dropdown:          1000;
@zindex-popover:           1060;
@zindex-tooltip:           1070;
@zindex-navbar-fixed:      1030;
@zindex-modal:             1040;
操作偽類

有用戶操作動(dòng)作的,需要定義偽類樣式如:active,hover,focus,disabled
有些組件有可能是多個(gè)或者是一個(gè)的偽類,最好在定義基礎(chǔ)樣式時(shí),預(yù)先定好。
不一定只有偽類定義,也可以定義類似偽類的類如:.active,.hover,.focus,.disabled。

//buttons
.btn {
  display: inline-block;
  margin-bottom: 0; // For input.btn
  font-weight: @btn-font-weight;
  text-align: center;
  vertical-align: middle;
  touch-action: manipulation;
  cursor: pointer;
  background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214
  border: 1px solid transparent;
  white-space: nowrap;
  .button-size(@padding-base-vertical; @padding-base-horizontal; @font-size-base; @line-height-base; @border-radius-base);
  .user-select(none);

  &,
  &:active,
  &.active {
    &:focus,
    &.focus {
      .tab-focus();
    }
  }

  &:hover,
  &:focus,
  &.focus {
    color: @btn-default-color;
    text-decoration: none;
  }

  &:active,
  &.active {
    outline: 0;
    background-image: none;
    .box-shadow(inset 0 3px 5px rgba(0,0,0,.125));
  }

  &.disabled,
  &[disabled],
  fieldset[disabled] & {
    cursor: @cursor-disabled;
    pointer-events: none; // Future-proof disabling of clicks
    .opacity(.65);
    .box-shadow(none);
  }
}
柵格系統(tǒng)

bootstrap最核心的就是柵格系統(tǒng)。

創(chuàng)造了.col-xs-1~.col-xs-12、.col-sm-1~.col-sm-12、.col-md-1~.col-md-12、.col-lg-1~.col-lg-12類的樣式

.make-grid-columns() {
  // 先循環(huán)出.col-xs-1, .col-sm-1, .col-md-1, .col-lg-1
  .col(@index) when (@index = 1) { // initial
    @item: ~".col-xs-@{index}, .col-sm-@{index}, .col-md-@{index}, .col-lg-@{index}";
    .col((@index + 1), @item);
  }
  //再把.col-xs-1, .col-sm-1, .col-md-1, .col-lg-1,與之后的遞增的類拼接起來形成
  // .col-xs-1, .col-sm-1, .col-md-1, .col-lg-1,.col-xs-2, .col-sm-2, .col-md-2, .col-lg-2,
  //.col-xs-1, .col-sm-1, .col-md-1, .col-lg-1,.col-xs-3, .col-sm-3, .col-md-3, .col-lg-3,
  
.col(@index, @list) when (@index =< @grid-columns) { // general; "=<" isn"t a typo
    @item: ~".col-xs-@{index}, .col-sm-@{index}, .col-md-@{index}, .col-lg-@{index}";
    .col((@index + 1), ~"@{list}, @{item}");
  }

 //最后把4*12 = 48 個(gè)類的樣式統(tǒng)一設(shè)置

  .col(@index, @list) when (@index > @grid-columns) { // terminal
    @{list} {
      position: relative;
      // Prevent columns from collapsing when empty
      min-height: 1px;
      // Inner gutter via padding
      padding-left:  (@grid-gutter-width / 2);
      padding-right: (@grid-gutter-width / 2);
    }
  }
  .col(1); // kickstart it
}

為每個(gè)帶col-xs-x, .col-sm-x, .col-md-x, .col-lg-x;添加浮動(dòng)。

.float-grid-columns(@class) {
  .col(@index) when (@index = 1) { // initial
    @item: ~".col-@{class}-@{index}";
    .col((@index + 1), @item);
  }
  .col(@index, @list) when (@index =< @grid-columns) { // general
    @item: ~".col-@{class}-@{index}";
    .col((@index + 1), ~"@{list}, @{item}");
  }
  .col(@index, @list) when (@index > @grid-columns) { // terminal
    @{list} {
      float: left;
    }
  }
  .col(1); // kickstart it
}

添加列偏移列排序,計(jì)算各個(gè)的寬度

.calc-grid-column(@index, @class, @type) when (@type = width) and (@index > 0) {
  .col-@{class}-@{index} {
    width: percentage((@index / @grid-columns));
  }
}
.calc-grid-column(@index, @class, @type) when (@type = push) and (@index > 0) {
  .col-@{class}-push-@{index} {
    left: percentage((@index / @grid-columns));
  }
}
.calc-grid-column(@index, @class, @type) when (@type = push) and (@index = 0) {
  .col-@{class}-push-0 {
    left: auto;
  }
}
.calc-grid-column(@index, @class, @type) when (@type = pull) and (@index > 0) {
  .col-@{class}-pull-@{index} {
    right: percentage((@index / @grid-columns));
  }
}
.calc-grid-column(@index, @class, @type) when (@type = pull) and (@index = 0) {
  .col-@{class}-pull-0 {
    right: auto;
  }
}
.calc-grid-column(@index, @class, @type) when (@type = offset) {
  .col-@{class}-offset-@{index} {
    margin-left: percentage((@index / @grid-columns));
  }
}

最后是調(diào)用

@grid-columns:12;
// Basic looping in LESS
.loop-grid-columns(@index, @class, @type) when (@index >= 0) {
  .calc-grid-column(@index, @class, @type);
  // next iteration
  .loop-grid-columns((@index - 1), @class, @type);
}

// Create grid for specific class
.make-grid(@class) {
  .float-grid-columns(@class);
  .loop-grid-columns(@grid-columns, @class, width);
  .loop-grid-columns(@grid-columns, @class, pull);
  .loop-grid-columns(@grid-columns, @class, push);
  .loop-grid-columns(@grid-columns, @class, offset);
}

.make-grid-columns();

.make-grid(xs);

@media (min-width: @screen-sm-min) {
  .make-grid(sm);
}

@media (min-width: @screen-md-min) {
  .make-grid(md);
}

@media (min-width: @screen-lg-min) {
  .make-grid(lg);
}
mixins border-radius
.border-top-radius(@radius) {
  border-top-right-radius: @radius;
   border-top-left-radius: @radius;
}
.border-right-radius(@radius) {
  border-bottom-right-radius: @radius;
     border-top-right-radius: @radius;
}
.border-bottom-radius(@radius) {
  border-bottom-right-radius: @radius;
   border-bottom-left-radius: @radius;
}
.border-left-radius(@radius) {
  border-bottom-left-radius: @radius;
     border-top-left-radius: @radius;
}
backgrounds
.bg-variant(@color) {
  background-color: @color;
  a&:hover {
    background-color: darken(@color, 10%);
  }
}
center-block
.center-block() {
  display: block;
  margin-left: auto;
  margin-right: auto;
}
clearfix
.clearfix() {
  &:before,
  &:after {
    content: " "; // 1
    display: table; // 2
  }
  &:after {
    clear: both;
  }
}
hide-text
.hide-text() {
  font: ~"0/0" a;
  color: transparent;
  text-shadow: none;
  background-color: transparent;
  border: 0;
}
img-responsive、.img-retina
.img-responsive(@display: block) {
  display: @display;
  max-width: 100%; // Part 1: Set a maximum relative to the parent
  height: auto; // Part 2: Scale the height according to the width, otherwise you get stretching
}

.img-retina(@file-1x; @file-2x; @width-1x; @height-1x) {
  background-image: url("@{file-1x}");

  @media
  only screen and (-webkit-min-device-pixel-ratio: 2),
  only screen and (   min--moz-device-pixel-ratio: 2),
  only screen and (     -o-min-device-pixel-ratio: 2/1),
  only screen and (        min-device-pixel-ratio: 2),
  only screen and (                min-resolution: 192dpi),
  only screen and (                min-resolution: 2dppx) {
    background-image: url("@{file-2x}");
    background-size: @width-1x @height-1x;
  }
}
opacity
.opacity(@opacity) {
  opacity: @opacity;
  // IE8 filter
  @opacity-ie: (@opacity * 100);
  filter: ~"alpha(opacity=@{opacity-ie})";
}
text-overflow
.text-overflow() {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
Vendor Prefixes

在vendor-prefixes.less里包含了

Animations、Backface visibility

Box shadow

Box sizing

Content columns

Hyphens

Placeholder text

Transformations

Transitions

User Select

以上是看bootstrap源碼的初步理解與感悟,都是自己感覺重要與技巧的總結(jié);如有不足之處請(qǐng)多多指教。
最后在前端的道路上蹣跚前行著。

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

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

相關(guān)文章

  • Bootstrap3.x - 代碼分析

    摘要:參照文檔與源代碼比較全面定義總結(jié)有意義的顏色。柵格系統(tǒng)最核心的就是柵格系統(tǒng)。創(chuàng)造了類的樣式。添加列偏移列排序,計(jì)算各個(gè)的寬度最后是調(diào)用在里包含了以上是看源碼的初步理解與感悟,都是自己感覺重要與技巧的總結(jié)如有不足之處請(qǐng)多多指教。 參照http://v3.bootcss.com/css/ 文檔與源代碼 colors 比較全面定義總結(jié)有意義的顏色。所有uI要用的顏色,都先從已定義的讀,這樣保...

    joyvw 評(píng)論0 收藏0
  • Bootstrap3.x - 代碼分析

    摘要:參照文檔與源代碼比較全面定義總結(jié)有意義的顏色。柵格系統(tǒng)最核心的就是柵格系統(tǒng)。創(chuàng)造了類的樣式。添加列偏移列排序,計(jì)算各個(gè)的寬度最后是調(diào)用在里包含了以上是看源碼的初步理解與感悟,都是自己感覺重要與技巧的總結(jié)如有不足之處請(qǐng)多多指教。 參照http://v3.bootcss.com/css/ 文檔與源代碼 colors 比較全面定義總結(jié)有意義的顏色。所有uI要用的顏色,都先從已定義的讀,這樣保...

    stormjun 評(píng)論0 收藏0
  • js 詞法分析,詞法作用域

    摘要:引擎會(huì)在代碼執(zhí)行前進(jìn)行詞法分析,所以事實(shí)上,運(yùn)行分為此法分析和執(zhí)行兩個(gè)階段。詞法作用域所謂詞法作用域是說,其作用域?yàn)樵诙x時(shí)詞法分析時(shí)就確定下來的,而并非在執(zhí)行時(shí)確定。 先來看個(gè)常見的面試題如下: var a = 10; function test(){ alert(a); //undefined var a = 20; alert(a); //20 } te...

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

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

0條評(píng)論

Anchorer

|高級(jí)講師

TA的文章

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