この記事では、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まず、正式なコードの記述を開始できます。インタラクションロジックを明確にします:
指を左右にスライドさせると、メインコンテナとメニューコンテナの両方が指の動きに合わせて動きます
指の移動距離がメニューコンテナの幅を超えると、ページを右にスライドし続けることはできません
指を左に動かすと、メニューとページ移動距離がゼロに戻ると、ページは左にスライドし続けることができなくなります
指を離したとき画面上で、ページが一定の距離(メニュー全体の幅の比率)を超えてスライドすると、メニュー全体が開き、一定の距離未満の場合はメニューが閉じられます
。パラメータを入力して、メニューの幅と、コンポーネントの使用時にメニューを閉じるトリガーとなる重要な値の比率をカスタマイズできるようにするために、最後に、タッチ イベントを追加する必要があります。メニューコンテナと本体を追加します。各コンテナは、その動きを制御するスタイルを追加します。このスタイルを制御することで、コンテナの動きを制御します
次に、コアのタッチイベント処理関数を実装しましょう。イベントのロジックは次のとおりです:
指が押された瞬間、現在の指が触れた点と現在のメインコンテナの位置が記録されます
指が動くと、その位置が記録されます。移動点が取得されます
<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>
<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: '250' }, ratio: { type: Number, default: 2 } }, data () { return { isMoving: false, transitionClass: '', 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) {} } }
上記は私が皆さんのためにまとめたもので、将来皆さんのお役に立てれば幸いです。
Vue ドキュメントの見落とされやすいいくつかの部分の詳細な分析
Baidu を使用する簡単な方法に関する簡単な説明Vue の下の地図以上がvue モバイル UI フレームワークを使用して QQ サイド メニューを実装する方法 (詳細なチュートリアル)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。