検索
ホームページウェブフロントエンドH5 チュートリアルAlloyTouch 全画面スクロール プラグインは 30 秒で滑らかな H5 ページを作成します

ジェスチャーの使用

全画面スクロールプラグインを設計するとき、私たちは開発者が次のことをできることを望んでいます:

スクリプトを書かずに絶妙なH5を素早く生成

PCスクロールホイールとモバイルタッチをサポート

クールなトランジションエフェクト

柔軟タイムライン管理

すべてが構成可能

しかし、スクリプトを書かないと柔軟性は絶対にありません? !いいえ。ここでは、HTML でいくつかのパラメータを設定できるだけでなく、プラグインのコールバック関数を通じていくつかのロジックを挿入することもできます。 AlloyTouch.FullPage の使用状況を分析するコードをスキャンして、上記の例の部分的な HTML を取り出してみましょう。

<div id="fullpage">
    <div>
      <div>
        <div class="animated" data-show="bounceInLeft" data-hide="bounceOutLeft">AlloyTouch Introduction</div>
        <div class="animated" data-delay="500" data-show="bounceInUp" data-hide="zoomOut"><img  src="/static/imghwm/default1.png"  data-src="asset/alloytouch.png"  class="lazy"   alt="AlloyTouch 全画面スクロール プラグインは 30 秒で滑らかな H5 ページを作成します" ></div>
        <div class="animated" data-delay="1200" data-show="bounceIn" data-hide="bounceOut">By AlloyTeam</div>
      </div>
    </div>
     
    <div>
      <div>
        <div class="animated" data-delay="100" data-show="flipInY" data-hide="flipOutY" >Powerful Features</div>
        <div class="animated" data-delay="400" data-show="zoomIn" data-hide="zoomOut"><img  src="/static/imghwm/default1.png"  data-src="asset/power.png"  class="lazy"   alt="AlloyTouch 全画面スクロール プラグインは 30 秒で滑らかな H5 ページを作成します" ></div>
      </div>
    </div>
    ...
    ...
    ...
 </div>

上記は HTML の一部にすぎず、何も含まれていない一部の HTML を削除していることに注意してください。プラグインの設定に関係します。それらを 1 つずつ分析してみましょう:

class="animated" は、animate.css の規則に準拠しています。このクラスを追加すると、アニメーションが存在することになります。

data-delay は、ページまでスクロールした後、マークされた DOM 要素がアニメーションの再生を開始するまでに待機する時間を表します。開発者がマークを付けなかった場合、デフォルト値は 0 です。

data-show は、マークされた DOM 要素によって表示されるアニメーション タイプを表します。

data-hide は、マークされた DOM 要素の非表示のアニメーション タイプを表します (これは通常、ユーザーには表示されませんが、表示中のスムーズさのために、通常は次のように設定されます)データと同じであること - 逆のタイプのショー)

非常に多く、非常に多くの構成、非常に多くの構成! !十分シンプルです! !

もちろん、jsで初期化する必要があります:

new AlloyTouch.FullPage("#fullpage",{
    animationEnd:function () {
     
    },
    leavePage: function (index) {
      console.log("leave"+index)
    },
    beginToPage: function (index) {
      console.log("to"+index);
      pb.to(index / (this.length-1));
    }
  });

animationEndはスクロール終了後のコールバック関数です

leavePageは特定のページから離れることを表すコールバック関数です

beginToPageは移動する予定のコールバック関数を表します特定のページへ

上記の pb は、ナビゲーションの進行状況または進行状況を設定するために使用されます。今のところこれは無視できます。必要に応じて、ユーザーは進行状況バーのコンポーネントを自分でカプセル化できます。

原理分析

ここでは主に分析のために AlloyTouch.FullPage のコアコードを抽出します:

new AlloyTouch({
  touch: this.parent,
  target: this.parent,
  property: "translateY",
  min: (1 - this.length) * this.stepHeight,
  max: 0,
  step: this.stepHeight,
  inertia: false,
  bindSelf : true,
  touchEnd: function (evt, v, index) {
    var step_v = index * this.step * -1;
    var dx = v - step_v;
 
    if (v < this.min) {
      this.to(this.min);
    } else if (v > this.max) {
      this.to(this.max);
    } else if (Math.abs(dx) < 30) {
      this.to(step_v);
    }else if (dx > 0) {
      self.prev();
    } else {
      self.next();
    }
    return false;
  },
  animationEnd: function () {
    option.animationEnd.apply(this,arguments);
    self.moving = false;
  }
});

ここでタッチされ移動される Dom はフルページ DOM であり、上記の this.parent です

上下スクロールなので、モーションの属性はtranslateY

minはwindow.innerHeightで計算でき、This.stepHeightはwindow.innerHeight

maxは明らかに0

stepです。 window.innerHeight、これは、.stepHeight

inertia: false は、慣性モーションが禁止されていることを意味します。つまり、ユーザーが手を離すと慣性スクロールは行われません

bindSelf は、touchmove、touchend、および touchcancel がすべて this.parent にバインドされていることを意味します。窓にではなく、それ自体に。 bindSelf が設定されていない場合、touchmove、touchend、および touchcancel はすべて window にバインドされます。

このbindSelf構成は、AlloyTouchのネストの問題を解決するのに非常に役立ちます。たとえば、上記のコードをスキャンして見た例では、AlloyTouch がネストされたデモは次のようになります:

AlloyTouch全屏滚动插件 30秒搞定顺滑H5页

これは実際にはネストされたスクロールです。内側を転がすと外側も転がりますか?どうやって対処すればいいのでしょうか?内部スクロールは、bindSelf を追加してバブリングを防ぐ必要があります:

内部スクロールの詳細なコードを見てみましょう:

var scroller = document.querySelector("#scroller");
Transform(scroller,true);
 
new AlloyTouch({
  touch:"#demo0",
  target: scroller,
  property: "translateY",
  min:250-2000,
  max: 0 ,
  touchStart:function(evt){
    evt.stopPropagation();
  },
  touchMove:function(evt){
    evt.stopPropagation();
  },
  bindSelf:true
})

この場合、ネストされた HTML 内のネストされた AlloyTouch はバブルアップしません。つまり、内部スクロールは発生しません。外側でスクロールをトリガーします。

FullPage ソース コードの分析を続けます:

touchEnd は、ユーザーの指が画面から離れた後のコールバック関数です。そこには境界処理ロジックがあります:

それが最小値と最大値を超える場合、対応する補正は最小値と最大値になります。

ステップ補正、絶対値が30px未満の場合はリセットされます。

ステップ補正、絶対値が30pxを超え、0より大きい場合は、前のページに移動します。絶対値が 30px より大きく 0 より小さい場合、次のページに進みます。

return false は、AlloyTouch が手を離した後にモーション補正ロジックを実行しないことを意味します。これは非常に重要です。移動終了後のコールバック関数は、AlloyTouch.FullPage からユーザーによって渡された animeEnd を実行し、移動を false に設定します。

AlloyTouch.FullPage の旅を始めましょう

Github: https://github.com/AlloyTeam/AlloyTouch

上記がこの記事の全内容であり、皆様の学習に役立つことを願っています。誰もが PHP 中国語 Web サイトをサポートします。

AlloyTouch 全画面スクロール プラグインの詳細については、30 秒でスムーズな H5 ページを作成できます。関連記事については、PHP 中国語 Web サイトに注目してください。

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

この記事では、&lt; audio&gt;を使用してHTML5にオーディオを埋め込む方法について説明します。フォーマット選択のベストプラクティス(MP3、OGG Vorbis)、ファイルの最適化、および再生のためのJavaScriptコントロールを含む要素。 複数のオーディオfを使用して強調しています

HTML5ページの可視性APIを使用して、ページが表示されたときに検出するにはどうすればよいですか?HTML5ページの可視性APIを使用して、ページが表示されたときに検出するにはどうすればよいですか?Mar 13, 2025 pm 07:51 PM

この記事では、HTML5ページの可視性APIを使用して、ページの可視性を検出し、ユーザーエクスペリエンスを向上させ、リソースの使用量を最適化します。重要な側面には、メディアの一時停止、CPU負荷の削減、視認性の変化に基づいて分析の管理が含まれます。

ViewPortメタタグを使用して、モバイルデバイスのページスケーリングを制御するにはどうすればよいですか?ViewPortメタタグを使用して、モバイルデバイスのページスケーリングを制御するにはどうすればよいですか?Mar 13, 2025 pm 08:00 PM

この記事では、ビューポートメタタグを使用してモバイルデバイスのページスケーリングを制御し、最適な応答性とパフォーマンスのために幅や初期スケールなどの設定に焦点を当てています。

ユーザー入力にHTML5フォームを使用する方法は?ユーザー入力にHTML5フォームを使用する方法は?Mar 10, 2025 pm 02:59 PM

この記事では、HTML5フォームを作成および検証する方法について説明します。 &lt; form&gt;の詳細要素、入力タイプ(テキスト、電子メール、番号など)、および属性(必須、パターン、MIN、最大)。 HTML5の利点は、古い方法よりも形成されます

Geolocation APIでユーザーの場所のプライバシーと許可を処理するにはどうすればよいですか?Geolocation APIでユーザーの場所のプライバシーと許可を処理するにはどうすればよいですか?Mar 18, 2025 pm 02:16 PM

この記事では、Geolocation APIを使用してユーザーの場所のプライバシーと許可を管理し、アクセス許可を要求するためのベストプラクティスを強調し、データセキュリティを確保し、プライバシー法を遵守することについて説明します。

HTML5とJavaScriptでインタラクティブなゲームを作成する方法は?HTML5とJavaScriptでインタラクティブなゲームを作成する方法は?Mar 10, 2025 pm 06:34 PM

この記事では、JavaScriptを使用してインタラクティブなHTML5ゲームの作成を詳述しています。 ゲームデザイン、HTML構造、CSSスタイリング、JavaScriptロジック(イベント処理とアニメーションを含む)、およびオーディオ統合をカバーしています。 必須JavaScriptライブラリ(Phaser、PI

インタラクティブなユーザーインターフェイスにHTML5ドラッグアンドドロップAPIを使用するにはどうすればよいですか?インタラクティブなユーザーインターフェイスにHTML5ドラッグアンドドロップAPIを使用するにはどうすればよいですか?Mar 18, 2025 pm 02:17 PM

この記事では、HTML5ドラッグアンドドロップAPIを使用してインタラクティブなユーザーインターフェイスを作成し、要素をドラッグ可能にし、キーイベントを処理し、カスタムフィードバックを使用してユーザーエクスペリエンスを強化する手順を作成する方法について説明します。また、aへの一般的な落とし穴についても説明します

クライアントとサーバー間の双方向通信にHTML5 WebSockets APIを使用するにはどうすればよいですか?クライアントとサーバー間の双方向通信にHTML5 WebSockets APIを使用するにはどうすればよいですか?Mar 12, 2025 pm 03:20 PM

この記事では、リアルタイムの双方向のクライアントサーバー通信のために、HTML5 WebSockets APIについて説明します。 クライアントサイド(JavaScript)とサーバー側(Python/Flask)の実装を詳述し、スケーラビリティ、状態管理、などの課題に対処します。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。