ホームページ  >  記事  >  ウェブフロントエンド  >  uniappで上にスライドしてナビゲーション効果を隠す方法を実現する方法

uniappで上にスライドしてナビゲーション効果を隠す方法を実現する方法

PHPz
PHPzオリジナル
2023-04-17 14:16:061150ブラウズ

モバイル APP の設計では、ナビゲーション バーは非常に重要な要素です。これにより、ユーザーは必要な情報をすばやく見つけることができ、APP の重要な視覚要素でもあります。ただし、設計プロセスでは、ナビゲーション バーのスタイルとレイアウトを考慮するだけでなく、さまざまなシナリオでのパフォーマンスとインタラクション効果にも注意を払う必要があります。

uniapp でナビゲーションをスライドダウンして非表示にする効果は比較的簡単に実現でき、いくつかの単純なスタイルと JS コードを使用するだけで実現できます。

まず、コンテナをページのナビゲーション領域に追加し、コンテナが常にページの先頭に表示されるように、position 属性を固定に設定し、z-index 属性をより高い値に設定します。スライドダウン後にナビゲーションを非表示にするには、transform 属性を使用してナビゲーション バーを画面の表示範囲外に移動します。

具体的な実装手順は次のとおりです。

  1. header という名前のナビゲーション コンテナを追加し、その中にナビゲーションのスタイルとレイアウトを追加します。
  2. ナビゲーション コンテナの初期位置を画面の上部に設定します。
  3. JS を使用して画面スクロール イベントをリッスンする ユーザーが下にスライドすると、ナビゲーション コンテナーが画面の表示範囲外に移動します。逆に、ユーザーが上にスワイプすると、ナビゲーション コンテナーは画面の上部に戻ります。

具体的なコード実装は次のとおりです:

// html文件代码
<template>
  <div class="wrapper">
    <header>
      <!--导航内容-->
    </header>
    <!--主要内容区域-->
  </div>
</template>

<style>
  header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 50px;
    background-color: #fff;
    z-index: 999;
    transition: all .3s ease-in-out; // 添加过渡效果
  }
  
  header.hide {
    transform: translateY(-100%);
  }
</style>

<script>
  export default {
    data() {
      return {
        lastScrollTop: 0,
        isHeaderShow: true
      }
    },
    mounted() {
      window.addEventListener('scroll', this.onScroll)
    },
    destroyed() {
      window.removeEventListener('scroll', this.onScroll)
    },
    methods: {
      onScroll(e) {
        const currentScrollTop = document.documentElement.scrollTop
        if (currentScrollTop > 0 && currentScrollTop > this.lastScrollTop) {
          this.isHeaderShow = false
        } else {
          this.isHeaderShow = true
        }
        this.lastScrollTop = currentScrollTop
      }
    },
    computed: {
      headerClass() {
        return {
          hide: !this.isHeaderShow
        }
      }
    }
  }
</script>

上記のコードでは、isHeaderShow 変数を使用して現在のナビゲーション バーを表示するかどうかをマークし、計算されたプロパティを使用してナビゲーション コンテナー Style をバインドし、JS メソッドにスクロール イベント リスナーを追加して、ナビゲーション バーを表示するかどうかを制御します。

ナビゲーション バーが正しく動作するには、ナビゲーション コンテナの高さを設定し、メイン コンテンツ領域の先頭に十分なスペースがあることを確認する必要があることに注意してください。そうしないと、ナビゲーションがバーがコンテンツ領域に重なる条件。

つまり、位置を固定に設定し、遷移効果と変換属性をナビゲーション コンテナに追加し、スクロール イベント リスニングを通じてナビゲーション コンテナの動きを制御することで、非常に簡単にスライドの効果を実現できます。下に押すと、uniapp のナビゲーションが非表示になります。

以上がuniappで上にスライドしてナビゲーション効果を隠す方法を実現する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。