Bootstrap 3 offset on right not left

后端 未结 9 1508
情歌与酒
情歌与酒 2020-12-07 18:25

In regards to BS 3 if I wanted just a narrow column of content on the right I might use an offset class of 9 and a column of 3.

However, what if I wanted the reverse

相关标签:
9条回答
  • 2020-12-07 18:37

    Based on WeNeigh's answer! here is a LESS example

    .col-offset-right(@i, @type) when (@i >= 0) {
        .col-@{type}-offset-right-@{i} {
            margin-right: percentage((@i / @grid-columns));
        }
        .col-offset-right(@i - 1, @type);
    };
    .col-offset-right(@grid-columns, xs);
    .col-offset-right(@grid-columns, sm);
    .col-offset-right(@grid-columns, md);
    .col-offset-right(@grid-columns, lg);
    
    0 讨论(0)
  • 2020-12-07 18:40

    I modified Bootstrap SASS (v3.3.5) based on Rukshan's answer

    Add this in the end of the calc-grid-column mixin in mixins/_grid-framework.scss, right below the $type == offset if condition.

    @if ($type == offset-right) {
          .col-#{$class}-offset-right-#{$index} {
              margin-right: percentage(($index / $grid-columns));
          }
      }
    

    Modify the make-grid mixin in mixins/_grid-framework.scss to generate the offset-right classes.

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

    You can then use the classes like col-sm-offset-right-2 and col-md-offset-right-1

    0 讨论(0)
  • 2020-12-07 18:41

    <div class="row">
    <div class="col-md-10 col-md-pull-2">
    col-md-10 col-md-pull-2
    </div>
    <div class="col-md-10 col-md-pull-2">
    col-md-10 col-md-pull-2
    </div>
    </div>

    0 讨论(0)
  • 2020-12-07 18:44

    Bootstrap rows always contain their floats and create new lines. You don't need to worry about filling blank columns, just make sure they don't add up to more than 12.

    <link rel="stylesheet" href="//maxcdn.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap.min.css">
    
    <div class="container">
      <div class="row">
        <div class="col-xs-3 col-xs-offset-9">
          I'm a right column of 3
        </div>
      </div>
      <div class="row">
        <div class="col-xs-3">
          I'm a left column of 3
        </div>
      </div>
      <div class="panel panel-default">
        <div class="panel-body">
          And I'm some content below both columns
        </div>
      </div>
    </div>

    0 讨论(0)
  • 2020-12-07 18:46

    Since Google seems to like this answer...

    If you're looking to match Bootstrap 4's naming convention, i.e. offset-*-#, here's that modification:

    .offset-right-12 {
      margin-right: 100%;
    }
    .offset-right-11 {
      margin-right: 91.66666667%;
    }
    .offset-right-10 {
      margin-right: 83.33333333%;
    }
    .offset-right-9 {
      margin-right: 75%;
    }
    .offset-right-8 {
      margin-right: 66.66666667%;
    }
    .offset-right-7 {
      margin-right: 58.33333333%;
    }
    .offset-right-6 {
      margin-right: 50%;
    }
    .offset-right-5 {
      margin-right: 41.66666667%;
    }
    .offset-right-4 {
      margin-right: 33.33333333%;
    }
    .offset-right-3 {
      margin-right: 25%;
    }
    .offset-right-2 {
      margin-right: 16.66666667%;
    }
    .offset-right-1 {
      margin-right: 8.33333333%;
    }
    .offset-right-0 {
      margin-right: 0;
    }
    @media (min-width: 576px) {
      .offset-sm-right-12 {
        margin-right: 100%;
      }
      .offset-sm-right-11 {
        margin-right: 91.66666667%;
      }
      .offset-sm-right-10 {
        margin-right: 83.33333333%;
      }
      .offset-sm-right-9 {
        margin-right: 75%;
      }
      .offset-sm-right-8 {
        margin-right: 66.66666667%;
      }
      .offset-sm-right-7 {
        margin-right: 58.33333333%;
      }
      .offset-sm-right-6 {
        margin-right: 50%;
      }
      .offset-sm-right-5 {
        margin-right: 41.66666667%;
      }
      .offset-sm-right-4 {
        margin-right: 33.33333333%;
      }
      .offset-sm-right-3 {
        margin-right: 25%;
      }
      .offset-sm-right-2 {
        margin-right: 16.66666667%;
      }
      .offset-sm-right-1 {
        margin-right: 8.33333333%;
      }
      .offset-sm-right-0 {
        margin-right: 0;
      }
    }
    @media (min-width: 768px) {
      .offset-md-right-12 {
        margin-right: 100%;
      }
      .offset-md-right-11 {
        margin-right: 91.66666667%;
      }
      .offset-md-right-10 {
        margin-right: 83.33333333%;
      }
      .offset-md-right-9 {
        margin-right: 75%;
      }
      .offset-md-right-8 {
        margin-right: 66.66666667%;
      }
      .offset-md-right-7 {
        margin-right: 58.33333333%;
      }
      .offset-md-right-6 {
        margin-right: 50%;
      }
      .offset-md-right-5 {
        margin-right: 41.66666667%;
      }
      .offset-md-right-4 {
        margin-right: 33.33333333%;
      }
      .offset-md-right-3 {
        margin-right: 25%;
      }
      .offset-md-right-2 {
        margin-right: 16.66666667%;
      }
      .offset-md-right-1 {
        margin-right: 8.33333333%;
      }
      .offset-md-right-0 {
        margin-right: 0;
      }
    }
    @media (min-width: 992px) {
      .offset-lg-right-12 {
        margin-right: 100%;
      }
      .offset-lg-right-11 {
        margin-right: 91.66666667%;
      }
      .offset-lg-right-10 {
        margin-right: 83.33333333%;
      }
      .offset-lg-right-9 {
        margin-right: 75%;
      }
      .offset-lg-right-8 {
        margin-right: 66.66666667%;
      }
      .offset-lg-right-7 {
        margin-right: 58.33333333%;
      }
      .offset-lg-right-6 {
        margin-right: 50%;
      }
      .offset-lg-right-5 {
        margin-right: 41.66666667%;
      }
      .offset-lg-right-4 {
        margin-right: 33.33333333%;
      }
      .offset-lg-right-3 {
        margin-right: 25%;
      }
      .offset-lg-right-2 {
        margin-right: 16.66666667%;
      }
      .offset-lg-right-1 {
        margin-right: 8.33333333%;
      }
      .offset-lg-right-0 {
        margin-right: 0;
      }
    }
    @media (min-width: 1200px) {
      .offset-xl-right-12 {
        margin-right: 100%;
      }
      .offset-xl-right-11 {
        margin-right: 91.66666667%;
      }
      .offset-xl-right-10 {
        margin-right: 83.33333333%;
      }
      .offset-xl-right-9 {
        margin-right: 75%;
      }
      .offset-xl-right-8 {
        margin-right: 66.66666667%;
      }
      .offset-xl-right-7 {
        margin-right: 58.33333333%;
      }
      .offset-xl-right-6 {
        margin-right: 50%;
      }
      .offset-xl-right-5 {
        margin-right: 41.66666667%;
      }
      .offset-xl-right-4 {
        margin-right: 33.33333333%;
      }
      .offset-xl-right-3 {
        margin-right: 25%;
      }
      .offset-xl-right-2 {
        margin-right: 16.66666667%;
      }
      .offset-xl-right-1 {
        margin-right: 8.33333333%;
      }
      .offset-xl-right-0 {
        margin-right: 0;
      }
    }
    
    0 讨论(0)
  • 2020-12-07 18:47

    Here is the same solution than Rukshan but in sass (in order to keep your grid configuration) for special case that don't work with Ross Allen solution (when you can't have a parent div.row)

    @mixin make-grid-offset-right($class) {
        @for $index from 0 through $grid-columns {
            .col-#{$class}-offset-right-#{$index} {
                margin-right: percentage(($index / $grid-columns));
            }
        }
    }
    
    @include make-grid-offset-right(xs);
    
    @media (min-width: $screen-sm-min) {
      @include make-grid-offset-right(sm);
    }
    
    @media (min-width: $screen-md-min) {
      @include make-grid-offset-right(md);
    }
    
    @media (min-width: $screen-lg-min) {
      @include make-grid-offset-right(lg);
    }
    
    0 讨论(0)
提交回复
热议问题