Как я могу использовать аффикс Bootstrap, чтобы зафиксировать элемент внизу, пока страница фактически не прокрутится вниз? - PullRequest
0 голосов
/ 05 сентября 2018

Я изо всех сил пытаюсь получить функцию аффикса Angular Strap , чтобы работать так, как мне бы хотелось. Я хочу прикрепить floater ниже к нижней части области просмотра вверх, пока пользователь не прокрутит близко к фактическому основанию. То есть поплавок должен быть видимым и зафиксированным до тех пор, пока страница не приблизится к нижней части, после чего она должна исчезнуть.

Однако, только data-offset-top работает на меня. Изменение на data-offset-bottom ничего не делает.

Есть идеи, почему это не работает? См. Фрагмент ниже или Codepen , в зависимости от того, что удобнее.

.floater {
  background-color: #eee;
  opacity: 0.7;
  padding: 20px 20px;
  border: 1px solid #111;
}

footer {
  background-color: #111;
  padding: 25px 25px;
  color: white;
} 
<!DOCTYPE html>
<html ng-app="myApp">

<head>
  
  <script src="https://code.jquery.com/jquery-1.9.1.min.js"></script>
  <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.5.8/angular.js"></script>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/angular-strap/2.1.6/angular-strap.js"></script>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/angular-strap/2.1.6/angular-strap.tpl.min.js"></script>
  <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
  
  <link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet"/>

   
  <script>
    var app = angular
      .module('myApp', ['mgcrea.ngStrap'])
      .controller('MainController', ['$scope', function($scope) {
        $scope.footerContent = "Yolo";
      }])
    console.log('app2', app);
  </script>
</head>

<body ng-controller="MainController">

  <header>
    <nav class="navbar navbar-default">
      <div class="container-fluid">
        <div class="navbar-header">
          <a class="navbar-brand" href="#">
        <img alt="Brand" src="">
      </a>
        </div>
      </div>
    </nav>
  </header>
  <main>
    <h1>Lorem ipsum dolor sit amet consectetuer adipiscing elit
    </h1>

    <p>Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor. Aenean massa
      <strong>strong</strong>. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec quam felis, ultricies nec, pellentesque eu, pretium quis, sem. Nulla consequat massa quis enim. Donec pede justo, fringilla vel,
      aliquet nec, vulputate eget, arcu. In enim justo, rhoncus ut, imperdiet a, venenatis vitae, justo. Nullam dictum felis eu pede <a class="external ext" href="#">link</a> mollis pretium. Integer tincidunt. Cras dapibus. Vivamus elementum semper nisi.
      Aenean vulputate eleifend tellus. Aenean leo ligula, porttitor eu, consequat vitae, eleifend ac, enim. Aliquam lorem ante, dapibus in, viverra quis, feugiat a, tellus. Phasellus viverra nulla ut metus varius laoreet. Quisque rutrum. Aenean imperdiet.
      Etiam ultricies nisi vel augue. Curabitur ullamcorper ultricies nisi.</p>

    <h1>Lorem ipsum dolor sit amet consectetuer adipiscing elit
    </h1>

    <h2>Aenean commodo ligula eget dolor aenean massa</h2>

    <p>Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor. Aenean massa. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec quam felis, ultricies nec, pellentesque eu, pretium
      quis, sem.</p>

    <h2>Aenean commodo ligula eget dolor aenean massa</h2>

    <p>Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor. Aenean massa. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec quam felis, ultricies nec, pellentesque eu, pretium
      quis, sem.</p>

    <ul>
      <li>Lorem ipsum dolor sit amet consectetuer.</li>
      <li>Aenean commodo ligula eget dolor.</li>
      <li>Aenean massa cum sociis natoque penatibus.</li>
    </ul>

    <p>Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor. Aenean massa. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec quam felis, ultricies nec, pellentesque eu, pretium
      quis, sem.</p>

    <form action="#" method="post">
      <fieldset>
        <label for="name">Name:</label>
        <input type="text" id="name" placeholder="Enter your 
full name" />

        <label for="email">Email:</label>
        <input type="email" id="email" placeholder="Enter 
your email address" />

        <label for="message">Message:</label>
        <textarea id="message" placeholder="What's on your 
mind?"></textarea>

        <input type="submit" value="Send message" />

      </fieldset>
    </form>

    <p>Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor. Aenean massa. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec quam felis, ultricies nec, pellentesque eu, pretium
      quis, sem.</p>

    <table class="data">
      <tr>
        <th>Entry Header 1</th>
        <th>Entry Header 2</th>
        <th>Entry Header 3</th>
        <th>Entry Header 4</th>
      </tr>
      <tr>
        <td>Entry First Line 1</td>
        <td>Entry First Line 2</td>
        <td>Entry First Line 3</td>
        <td>Entry First Line 4</td>
      </tr>
      <tr>
        <td>Entry Line 1</td>
        <td>Entry Line 2</td>
        <td>Entry Line 3</td>
        <td>Entry Line 4</td>
      </tr>
      <tr>
        <td>Entry Last Line 1</td>
        <td>Entry Last Line 2</td>
        <td>Entry Last Line 3</td>
        <td>Entry Last Line 4</td>
      </tr>
    </table>

    <p>Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor. Aenean massa. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec quam felis, ultricies nec, pellentesque eu, pretium
      quis, sem.</p>

  </main>

  <div class="floater" bs-affix data-offset-top="0">
    This is the floater
  </div>

  <footer>
    <div class="container-fluid">
      © 2017 Copyright: <a href=""> Footer content: {{footerContent}} </a>
    </div>
  </footer>

</body>

</html>
...