この記事では、主に既存のコンポーネント(WeChatアプレットのスワイパーやh5でよく使われるswiper.jsなど)をベースにスライダースタイルのインジケーターパネルを実装する方法を紹介します。デモはミニプログラムに基づいていますが、ロジックは普遍的です。 背景最近、新しいミニプログラムに取り組んでいます。ホームページにスワイパーモジュールがあります。デザインクラスメイトの素晴らしい仕事のおかげで😭、退屈な開発に喜びを見出すことができました。スワイパーのインジケーターパネルのドットがスライダーに変更されました。正直、ドットを一列に並べてクリックするだけでいいんじゃないでしょうか?ハハハハ。でも私は彼が大好きよ〜 ターゲット効果全体的にシンプルです。主に下部のスライダーに若干の作業が必要です。要件を整理した後、実装する必要がある機能ポイントは次のとおりです。
アイデア整理後の実施計画は次のようになります。
成し遂げるスワイパーは変更を聞きますまず、スワイパーの変更イベントを使用する必要があります。コードは次のとおりです。 <スワイパー クラス="ホットコンテンツスワイパー" インジケータードット="{{indicatorDots}}" vertical="{{vertical}}" バインドチェンジ="スライダーハンドラー"> <block wx:for="{{popular_zone_list}}" wx:key="*this"> <スワイパーアイテム> <view class="hot-list"> これはスワイパー{{index}}です </ビュー> </スワイパーアイテム> </ブロック> </スワイパー> カスタムドットモジュール次に、スライダー領域であるドットの DOM をカスタマイズする必要があります。コードは次のとおりです。 <ビュークラス="dot"> <view class="dot-bar" style="width: {{dotBarWidth}}rpx"></view> </ビュー> これには、スライダーに初期サイズを指定する必要があります。そうしないと、スライド後の幅の変化にジッター (dotBarWidth) が発生します。 スライダーのサイズは、スライドの長さとスワイパー項目の数に基づいて計算されます。この方法で幅を取得したら、スライダー幅の倍数でオフセットするだけです。 ドット幅を100とします。 dotBarWidth = Math.round(dotWidth/popular_zone_list.length); とします。 変更イベントのロジックテンプレートが記述されたので、変更イベントの記述を始めましょう。コードは次のとおりです。 スライダーハンドラ({詳細}) { curPage = detail.current; とします。 自分自身 = this とします。 this.animate('.dot-bar', [ { translateX: self.prePage * 100 + '%', 変換元: 'center'、 }, { translateX: curPage*100 + '%', 変換元: 'center'、 }, ], 100, function () { // アニメーションコールバック self.prePage = curPage; self.clearAnimation('.container', { translateX: 真、 変換元: true }); }); }, // ミニプログラムでない場合は、this.animate を動的にバインドされたスタイルまたはその他の DOM 操作に置き換えることができます。 この機能が実装された今、この機能は非常にシンプルでかなり優れていると思いませんか?😒 最後に正直に言うと、実装の過程で、当時の私の状態と関係があるかもしれないが、いくつか愚かなことをしてしまった。スライダーが左にスライドされたのか、右にスライドされたのかを判断することに集中しすぎて、遠回りをしてしまったのだ。しかし、結果に基づいて、開始位置と終了位置を計算するだけでよく、左スワイプの開始位置は終了位置よりも大きくする必要があることがわかりました。上記のスキームが参考になれば幸いです〜🎉 WeChatミニプログラムのスワイパードットのドットをスライダーに変更する方法についての記事はこれで終わりです。WeChatミニプログラムのスワイパードットのドットをスライダーに変更する方法に関するより関連性の高いコンテンツについては、123WORDPRESS.COMで以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後も123WORDPRESS.COMを応援していただければ幸いです。 以下もご興味があるかもしれません:
|
<<: Mysql SSHトンネル接続を使用するための基本的な手順
1. 心の旅最近コックピットを書いていたときに、背景画像を単純に特定の角度に回転させるという問題につ...
目次古典的なアプローチ質問その他の質問注意が必要な問題古典的なアプローチご存知のとおり、アカウントの...
目次1. HTTP範囲リクエスト1.1 範囲構文2. 大きなファイルをダウンロードする方法2.1 補...
今日は、スライドを使用する原理に似た、Taobao のフロントエンドのマウス ズーム効果に慣れました...
誰もがボックス モデルの構成を、内側から外側まで、コンテンツ、パディング、境界線、マージンについて知...
この記事の例では、計算機機能を実装するためのミニプログラムの具体的なコードを参考までに共有しています...
最近、センタリングの問題に数多く遭遇したので、後で簡単に見つけられるように、時間をかけてそれらを要約...
目次序文デザイン成し遂げるまとめ序文最近は、いつも延々とスワイプしています。 Weibo をチェック...
背景コメントに似た機能を開発する場合は、必要に応じてすべてのコメントのサブセットをクエリする必要があ...
1. inodeの紹介inode を理解するには、まずファイル ストレージから始める必要があります。...
この記事では、キャンバスを使用して画像圧縮アップロードを実現するVueの具体的なコードを参考までに共...
目次導入インデックスの原則1. データページ2. ページディレクトリ3. インデックス原則分析要約す...
開発環境ウィンドウ開発ツール Visual Studio Codeノードのインストールとnpm Wi...
文法以下は、MySQL テーブルにデータを挿入するための INSERT INTO コマンドの一般的な...
目次 はじめに 同期 非同期とブロッキング JavaScript のノンブロッキング コールバック ...