今回は、サイドメニュープラグインエフェクトを実装するためのvueモバイルターミナルのUIフレームワークについて説明します。 サイドメニュープラグインを実装するための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>
CSSスタイル
私のプロジェクトでは 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>
絶対に配置された
コンテナ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) {} } }
touchstart (e) { this.oldPoint.x = e.touches[0].pageX this.oldPoint.y = e.touches[0].pageY this.startPoint.x = this.move.x this.startPoint.y = this.move.y this.setTransition() }, touchmove (e) { let newPoint = { x: e.touches[0].pageX, y: e.touches[0].pageY } let moveX = newPoint.x - this.oldPoint.x let moveY = newPoint.y - this.oldPoint.y if (Math.abs(moveX) < Math.abs(moveY)) return false e.preventDefault() this.isMoving = true moveX = this.startPoint.x * 1 + moveX * 1 moveY = this.startPoint.y * 1 + moveY * 1 if (moveX >= this.width) { this.move.x = this.width } else if (moveX <= 0) { this.move.x = 0 } else { this.move.x = moveX } }, touchend (e) { this.setTransition(true) this.isMoving = false this.move.x = (this.move.x > this.width / this.ratio) ? this.width : 0 }, setTransition (isTransition = false) { this.transitionClass = isTransition ? 'r-slide-menu-transition' : '' }
AngularJS でルーティング ページをリロードする方法
以上がvueモバイル端末のUIフレームワークでサイドメニュープラグイン効果を実現の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。