はじめに
Web アプリケーションでは、ページがスクロールされるときに、ページ内の 1 つ以上の要素を固定位置に保持する必要があることがよくあります。この効果は、要素がページの上部に貼り付けられているかのように所定の位置に留まるため、天井効果と呼ばれることがあります。
Vue では、天井効果を実現するさまざまな方法があります。この記事では、これらの方法の 1 つについて説明し、サンプル コードを示します。
方法
Vueで天井効果を実現する方法は、ページスクロールイベントをリッスンし、現在のスクロール位置と天井要素の位置関係を計算し、CSSを動的に追加または削除します。スタイルを達成します。
具体的な手順は次のとおりです。
isFixed
という変数を使用します。 data() { return { isFixed: false } },
mounted
フック関数に、ページ スクロール イベント リスナーを追加します。 mounted() { window.addEventListener('scroll', this.handleScroll) },
handleScroll
を methods
で定義し、現在のスクロール位置と天井要素の間の距離を計算します。この関数の位置関係。 methods: { handleScroll() { const scrollTop = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop const testEle = this.$refs.test if (scrollTop > testEle.offsetTop) { this.isFixed = true } else { this.isFixed = false } } },
上記のコードでは、現在のページのスクロール位置と天井要素の位置を取得します (要素の参照を取得するには、$refs
を使用します)。次に、現在のスクロール位置と天井要素の位置関係に基づいて、isFixed
変数の値を設定します。
class
属性で、fixed
クラス名を動的にバインドします。クラス名の外観は、 isFixed# によって異なります。 ## 変数の値。
<div ref="test" :class="{fixed: isFixed}"> // 吸顶元素的内容 </div>
<template> <div> <div class="header"> // 头部元素的内容 </div> <div ref="test" :class="{fixed: isFixed}"> // 吸顶元素的内容 </div> <div class="content"> // 页面内容 </div> </div> </template> <script> export default { data() { return { isFixed: false } }, mounted() { window.addEventListener('scroll', this.handleScroll) }, methods: { handleScroll() { const scrollTop = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop const testEle = this.$refs.test if (scrollTop > testEle.offsetTop) { this.isFixed = true } else { this.isFixed = false } } } } </script> <style> .fixed { position: fixed; top: 0; left: 0; right: 0; z-index: 99; } .header { height: 100px; background-color: #eee; } .content { height: 2000px; } </style>
fixed クラス名を使用して天井要素の固定位置を制御し、いくつかの単純な CSS スタイルを設定します。
以上がVueで天井効果を実現する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。