この記事では、画像カルーセル効果を実現するために Swiper をカプセル化する Vue のコードを主に説明します。画像カルーセルは、フロントエンドで実装する必要があることが多い機能です。最近、Vue.js を学び、Swiper をカプセル化して、単純な画像カルーセル コンポーネントを実装しました。
1. Swiper
カプセル化を実装する前に、まず Swiper を紹介します。
Swiper は、純粋な Javascript で作成されたスライド特殊効果プラグインで、携帯電話、タブレット、その他のモバイル端末を対象としています。
スワイパーは、タッチスクリーンのフォーカス画像、タッチスクリーンのタブ切り替え、タッチスクリーンのマルチ画像切り替えなどの一般的な効果を実現できます。
Swiper はオープンソースで、無料で、安定していて、使いやすく、強力です。モバイル端末の Web サイトを構築するための重要な選択肢です。
Swiper には幅広い応用シナリオがあり、導入効果は非常に優れています。以下の実際のケースは、Swiper の典型的な応用シナリオです。
Swiper の具体的な使い方チュートリアルと詳細な API については、Swiper 中国語 Web サイト
を参照してください。
2. Vue コンポーネント
Vue コンポーネントは本来、保守性と再利用性を向上させるために一緒に使用するように設計されています。画像カルーセルはコンポーネントを使用して完成させるのに適しているため、具体的な実装を紹介する前に、まず Vue コンポーネントとコンポーネント通信について紹介します。
Vue コンポーネント間の最も一般的な関係は、親コンポーネントと子コンポーネント間の関係です。コンポーネント A はそのテンプレートでコンポーネント B を使用します。
それらは相互に通信する必要があります。親コンポーネントは子コンポーネントにデータを送信する必要がある場合があり、子コンポーネントは内部で何が起こっているかを親コンポーネントに通知する必要がある場合があります。ただし、明確に定義されたインターフェイスを通じて、親コンポーネントと子コンポーネントをできるだけ分離することも重要です。これにより、各コンポーネントのコードを比較的独立した環境で記述して理解できるようになり、保守性と再利用性が向上します。
Vue では、親コンポーネントと子コンポーネントの関係は、props が下方に渡され、イベントが上方に渡されるとして要約できます。親コンポーネントは props を通じて子コンポーネントにデータを送信し、子コンポーネントはイベントを通じて親コンポーネントにメッセージを送信します。
3. カプセル化の実装
1. Swiper の導入
まず、Swiper をインストールする必要があります。
npm install --save swiper
それでは、参照するファイルが 2 つあります。
import Swiper from "swiper"; import "swiper/dist/css/swiper.min.css";
2.HTMLコード
テンプレートにカルーセルのHTMLレイアウトを設定します。
<template> <p class="swiper-container" :class="swipeid"> <p class="swiper-wrapper"> <!-- 存放具体的轮播内容 --> <slot name ="swiper-con"></slot> </p> <!-- 分页器 --> <p :class="{'swiper-pagination':pagination}"></p> </p> </template>
名前付きスロットを使用して分離を改善するため、親コンポーネントが使用されるときに、さまざまな状況に応じてさまざまなカルーセル コンテンツを設定できます。
さらに、画像カルーセル内のページインジケーターであるページャーを設定する必要があります。一般的なものは小さなドットまたはデジタルインジケーターです。
3. Swiper を初期化する
Swiper はカルーセル画像を実装するためにカプセル化されており、Swiper は以前にインストールされているため、ここで初期化する必要があります。
初期化の前に、Swiperの使い方の理解に基づいて、まずカルーセルコンポーネントに必要な属性情報を決定し、それを親コンポーネントを通じてカプセル化されたSwiperコンポーネントに渡します。
この時点では小道具を使用する必要があります。
props: { swipeid: { type: String, default: "" }, effect: { type: String, default: "slide" }, loop: { type: Boolean, default: false }, direction: { type: String, default: "horizontal" }, pagination: { type: Boolean, default: true }, paginationType: { type: String, default: "bullets" }, autoPlay: { type: Number, default: 3000 } }
以下では各属性の意味を一つずつ説明していきます。
属性 | 意味 |
---|---|
スワイプ | カルーセルコンテナクラス属性のクラス名。 |
エフェクト | 画像の切り替えエフェクト。デフォルトは「スライド」ですが、「フェード」、「キューブ」、「カバーフロー」、「フリップ」にも設定できます。詳細についてはエフェクトを参照してください。 |
loop | ループモードを有効にするには、true に設定します。ループ モード: 元の画像の前後に複数の画像がコピーされ、適切なタイミングで切り替わり、スワイパーがループしているように見えます。詳細については、「ループ」を参照してください。 |
方向 | 画像のスライド方向は、水平または垂直に設定できます。詳細については、方向を参照してください。 |
ページネーション | ページネーションナビゲーションを使用します。詳細については、ページネーションを参照してください。 |
paginationType | 分页器样式类型,可设置为"bullets", "fraction", "progressbar", "custom",详情见type。 |
autoPlay | 设置为true启动自动切换,并使用默认的切换设置,详情见autoplay。 |
了解了上面每个属性的含义,下面就可以初始化Swiper,并设置具体的属性。
初始化Swiper时,需要传入两个参数。
轮播容器的类名
代表图片轮播组件详细功能的对象
var that = this; this.dom = new Swiper("." + that.swipeid, { //循环 loop: that.loop, //分页器 pagination: { el: ".swiper-pagination", bulletClass : 'swiper-pagination-bullet', }, //分页类型 paginationType: that.paginationType, //自动播放 autoPlay: that.autoPlay, //方向 direction: that.direction, //特效 effect: that.effect, //用户操作swiper之后,不禁止autoplay disableOnInteraction: false, //修改swiper自己或子元素时,自动初始化swiper observer: true, //修改swiper的父元素时,自动初始化swiper observeParents: true }); }
四、自定义轮播效果
经过上面的步骤,轮播器就封装好了。我们可以自定义实现自己想要的轮播器效果。下面以知乎的API为例,实现图片轮播。
1.HTML代码
<m-swipe swipeid="swipe" ref="swiper" :autoPlay="3000" effect="slide"> <p v-for="top in tops" :key="top.id" class="swiper-slide" slot="swiper-con" > <img :src="top.image"> <h3>{{top.title}}</h3> </p> </m-swipe>
首先要引用注册组件,这里就不详细写出。
其中 m-swipe 就是前面实现的图片轮播组件,而其中的子组件就是通过具名插槽插入的轮播内容。
2.CSS代码
.swiper-container { width: 100%; } .swiper-slide { height: 8rem; overflow: hidden; position: relative; } .swiper-slide { p { top: 0; left: 0; width: 100%; height: 100%; opacity: 0.4; position: absolute; background-color: @blue; } img { top: 50%; position: relative; transform: translate(0, -50%); } h3 { width: 70%; color: #fff; margin: 0; font-size: 0.5rem; line-height: 1rem; right: 5%; bottom: 2.6rem; text-align: right; position: absolute; text-shadow: 1px 1px 10px rgba(0, 0, 0, 0.5); &:before { content: ""; width: 3rem; bottom: -0.6rem; right: 0; display: block; position: absolute; border: 2px solid @yellow; } } } .swiper-pagination-bullet-active { background: #fff; } .swiper-container-horizontal > .swiper-pagination-bullets { bottom: 1rem; width: 95%; text-align: right; }
其中 swiper-pagination-bullet-active 代表分页器中当前指示的小圆点的类名。 .swiper-pagination-bullets 代表分页器的类名,详情见pagination分页器内元素的类名 。
关于网络请求数据展示的代码就不贴了,下面有源码地址。
3.效果
这只是一个简单的封装效果,想要实现更多的效果,可以通过Swiper中提供的更多功能来实现。
相关推荐:
以上がVue は Swiper をカプセル化し、画像カルーセル効果のコード共有を実装します。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。