ホームページ >ウェブフロントエンド >jsチュートリアル >vue モバイル UI フレームワークを使用して QQ サイド メニューを実装する方法 (詳細なチュートリアル)

vue モバイル UI フレームワークを使用して QQ サイド メニューを実装する方法 (詳細なチュートリアル)

亚连
亚连オリジナル
2018-05-31 16:05:422461ブラウズ

この記事では、QQ のようなサイド メニュー コンポーネントを実装するための vue モバイル UI フレームワークを主に紹介します。これは非常に優れており、必要とする友人は参照できます。

最近のインタビューでは、多くのフロントエンド プログラマーがこのフレームワークを使用していることがわかりました。エクスペリエンスは基本的に Baidu で見つかります。そこで私は、コンポーネントを書いたことのない兄弟たちにプラグインの書き方を段階的に教える一連の記事を書くつもりです。この一連の記事はすべて VUE に基づいており、コアの内容は同じです。理解した後は、React、Angular、または小さなプログラムなどのコンポーネントにすぐに書き直すことができます。この記事は最初の記事で、QQ に似たサイド メニュー コンポーネントについて説明します。

エフェクト表示

最初にエフェクト表示を見て、何をしたいのかを理解してもらいましょう。画像が少しぼやけているので、最初にクリックしてみましょう:

作成を開始します

DOM 構造

全体的な構造には 2 つのコンテナがあるはずです: 1. メニュー コンテナ 2. メイン ページ コンテナ; したがって、現在の DOM 構造は次のとおりです:

<template>
 <p class="r-slide-menu">
 <p class="r-slide-menu-wrap"></p>
 <p class="r-slide-menu-content"></p>
 </p>
</template>

メニュー コンテンツとテーマ コンテンツをカスタマイズするには、さらに 2 つのスロットを 2 つのコンテナに追加します。メイン コンテンツはデフォルトのスロットに配置され、メニューはメニュー スロットに配置されます。

私のプロジェクトでは scss を使用しています。コードは次のとおりです:

<template>
 <p class="r-slide-menu">
 <p class="r-slide-menu-wrap">
  <slot name="menu"></slot>
 </p>
 <p class="r-slide-menu-content">
  <slot></slot>
 </p>
 </p>
</template>

この時点で、絶対に配置されたコンテナが 2 つあります

javascript

まず、正式なコードの記述を開始できます。インタラクションロジックを明確にします:

指を左右にスライドさせると、メインコンテナとメニューコンテナの両方が指の動きに合わせて動きます

指の移動距離がメニューコンテナの幅を超えると、ページを右にスライドし続けることはできません

  • 指を左に動かすと、メニューとページ移動距離がゼロに戻ると、ページは左にスライドし続けることができなくなります

  • 指を離したとき画面上で、ページが一定の距離(メニュー全体の幅の比率)を超えてスライドすると、メニュー全体が開き、一定の距離未満の場合はメニューが閉じられます

  • 。パラメータを入力して、メニューの幅と、コンポーネントの使用時にメニューを閉じるトリガーとなる重要な値の比率をカスタマイズできるようにするために、最後に、タッチ イベントを追加する必要があります。メニューコンテナと本体を追加します。各コンテナは、その動きを制御するスタイルを追加します。このスタイルを制御することで、コンテナの動きを制御します

  • 次に、コアのタッチイベント処理関数を実装しましょう。イベントのロジックは次のとおりです:

指が押された瞬間、現在の指が触れた点と現在のメインコンテナの位置が記録されます

指が動くと、その位置が記録されます。移動点が取得されます

    Move によって移動された距離の場合は X、Y 軸の距離を計算し、その場合は 2 つのコンテナの位置を変更します (移動中にページ上の他のイベントがトリガーされないようにします)
  1. 指が画面から離れる: 累積移動距離が臨界値を超えた場合、アニメーションを使用してメニューを開き、そうでない場合はメニューを閉じます
  2. <style lang="scss">
    @mixin one-screen {
     position: absolute;
     left:0;
     top:0;
     width:100%;
     height:100%;
     overflow: hidden;
    }
    
    .r-slide-menu{
     @include one-screen;
     &-wrap, &-content{
     @include one-screen;
     }
     &-transition{
     -webkit-transition: transform .3s;
     transition: transform .3s;
     }
    }
    </style>

  3. 上記のコア コードには setTransition 関数があります。この関数の機能は、指が離れたときにコンテナ要素に遷移属性を追加して、コンテナが閉じるアニメーションまたは開くアニメーションを完了するための遷移アニメーションを持つようにすることです。そのため、コンテナの遷移属性を削除する必要があります。容器と指の滑りが遅くなるという不快な経験を避けるために、指が押される瞬間を考慮します。 最後に注意しておきますが、コード内でtranslateの代わりにtranslate3dを使用する理由は、携帯電話でのアニメーションの3Dアクセラレーションを有効にし、アニメーションの滑らかさを向上させるためです。最終的なコードは次のとおりです:
  4. <template>
     <p class="r-slide-menu">
     <p class="r-slide-menu-wrap" :style="wrapStyle">
      <slot name="menu"></slot>
     </p>
     <p class="r-slide-menu-content" :style="contentStyle"
     @touchstart="touchstart"
     @touchmove="touchmove"
     @touchend="touchend">
      <slot></slot>
     </p>
     </p>
    </template>
    <script>
    export default {
     props: {
     width: {
      type: String,
      default: &#39;250&#39;
     },
     ratio: {
      type: Number,
      default: 2
     }
     },
     data () {
     return {
      isMoving: false,
      transitionClass: &#39;&#39;,
      startPoint: {
      X: 0,
      y: 0
      },
      oldPoint: {
      x: 0,
      y: 0
      },
      move: {
      x: 0,
      y: 0
      }
     }
     },
     computed: {
     wrapStyle () {
      let style = {
      width: `${this.width}px`,
      left: `-${this.width / this.ratio}px`,
      transform: `translate3d(${this.move.x / this.ratio}px, 0px, 0px)`
      }
      return style
     },
     contentStyle () {
      let style = {
      transform: `translate3d(${this.move.x}px, 0px, 0px)`
      }
      return style
     }
     },
     methods: {
     touchstart (e) {},
     touchmove (e) {},
     touchend (e) {}
     }
    }
  5. 上記は私が皆さんのためにまとめたもので、将来皆さんのお役に立てれば幸いです。

  6. 関連記事:

Angular CLI を使用してブループリントからコードを生成する方法の詳細な説明

Vue ドキュメントの見落とされやすいいくつかの部分の詳細な分析

Baidu を使用する簡単な方法に関する簡単な説明Vue の下の地図


以上がvue モバイル UI フレームワークを使用して QQ サイド メニューを実装する方法 (詳細なチュートリアル)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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