Affix プラグインを使用すると、
1. 使用方法
Affix プラグインは、データ属性または JavaScript 経由で使用できます。
1. data 属性を介して: 追加のナビゲーション (Affix) 動作を要素に追加する必要がある場合は、監視する必要がある要素に data-spy="affix" を追加するだけです。オフセットを使用して、要素のロックと移動をいつ切り替えるかを定義します。
2. JavaScript を使用: JavaScript
を使用して要素に追加のナビゲーション (Affix) を手動で追加できます。
2. CSS による配置
Affix プラグインを使用する上記のどちらの方法でも、CSS を介してコンテンツを配置する必要があります。 Attached Navigation (Affix) プラグインは、.affix、.affix-top、および .affix-bottom という特定の状態を表す 3 つのクラスを切り替えます。これら 3 つの状態に独自の CSS を設定するには、以下の手順に従ってください (このプラグインに依存せずに)。
1. プラグインは最初に、要素が先頭の位置にあることを示す .affix-top を追加します。現時点では CSS の位置決めは必要ありません。
2. 追加ナビゲーション (Affix) が追加された要素をスクロールして過ぎると、実際の追加ナビゲーション (Affix) がトリガーされる必要があります。現時点では、.affix は .affix-top を置き換え、position:fixed を設定します (Bootstrap の CSS コードによって提供されます)。
3. 下部オフセットが定義されている場合、スクロールがこの位置に到達すると、.affix を .affix-bottom に置き換える必要があります。オフセットはオプションであるため、オフセットを設定するには適切な CSS も設定する必要があります。この場合、必要に応じて、position:Absolute; を追加します。
3. オプション
一部のオプションはデータ属性または JavaScript を介して渡されます。オプションは以下の表にリストされています:
4. 例
アンカー機能を実装するために、追加のナビゲーションが画面上のどこかに貼り付けられます。
1. 基本的な例
<body data-spy="scroll" data-target="#myScrollspy"> <div class="container"> <div class="jumbotron" style="height:150px"> <h1>Bootstrap Affix</h1> </div> <div class="row"> <div class="col-xs-3" id="myScrollspy"> <ul class="nav nav-pills nav-stacked" data-spy="affix"data-offset-top="150"> <li class="active"> <a href="#section-1">第一部分 </a> </li> <li> <a href="#section-2">第二部分</a> </li> <li> <a href="#section-3">第三部分</a> </li> <li> <a href="#section-4">第四部分</a> </li> <li> <a href="#section-4">第五部分</a> </li> </ul> </div> <div class="col-xs-9"> <h2 id="section-1">第一部分</h2> <p> ... </p> <h2 id="section-2">第二部分</h2> <p> ... </p> <h2 id="section-3">第三部分</h2> <p> ... </p> <h2 id="section-4">第四部分</h2> <p> ... </p> <h2 id="section-5">第四部分</h2> <p> ... </p> </div> </div> </div>
2. ナビゲーションの CSS 部分
ul.nav-pills { width: 200px; } ul.nav-pills.affix { top: 30px; } //JavaScript 代替 data-spy="affix" data-offset-top="125" $('#myAffix').affix({ offset : { top : 150 } })
デフォルトで上部を使用しますが、もちろんデフォルトで下部にすることもできます。この配置方法は、CSS を通じて直接配置されます。
//设置成 bottom ul.nav-tabs.affix-bottom { bottom: 30px; } //设置成 bottom $('#myAffix').affix({ offset : { bottom : 150 } })
Affix には次のような複数のイベントが含まれています:
//其他雷同 $('#myAffix').on('affixed-top.bs.affix', function() { alert('触发!'); });
詳細については、ブートストラップ学習チュートリアル
を参照してください。以上がこの記事の全内容です。皆様の学習のお役に立てれば幸いです。