Shopifyの無限スライダー(カルーセル)をコピペだけで5分実装する方法
こんにちは!Shopifyエンジニアのりょうま(@ryoo_black)です。
- ストアの見栄えを良くしたいけど、プログラミングの知識が不安…。
- Web制作会社に依頼すると費用がかかる…。
そんな悩みを抱えていませんか?
今回は、無料テーマでもおしゃれな「流れ続けるスライダー」を実装する方法を、画像付きで詳しく解説します。コピペだけの5分で完了するので、プログラミング初心者の方でも安心して実装できます!
Shopifyでスライダーを実装する方法
Shopifyでスライダーを実装する方法は、主に以下の3つがあります
- アプリを使用する方法
- テーマのカスタマイズ機能を使用する方法
- コードを編集する方法
アプリを使用する方法については、以下の記事が詳しいのでおすすめです
data:image/s3,"s3://crabby-images/21322/21322db29acabee93b67fc8121e880f4fb34fb8f" alt=""
テーマのカスタマイズ機能については、以下が参考になります
この記事では、コードを編集してスライダーを実装する方法を詳しく解説します。
Swiperを使用して作成しますが、以下の記事ではSwiperの基本的な使用方法を解説していますので、あわせて参考にしてみてください
data:image/s3,"s3://crabby-images/74910/749107f3e472d0e7773a74d1b7081d215d97d3ca" alt=""
コードを直接編集することで、費用をかけずに自由度の高いスライダーを作ることができ、さらにサイトの表示速度への影響も最小限に抑えられます。
それでは、具体的な実装手順を見ていきましょう。
完成イメージ
以下のような流れ続けるスライダーをswiperを使用して実装していきます。
data:image/s3,"s3://crabby-images/a6d40/a6d40dd055146537f726a5de137c91033e46b959" alt="Shopifyの無限スライダー(カルーセル)の完成イメージ"
スライダーの実装手順
管理画面の「オンラインストア」の「テーマ」から「3点リーダー」をクリックし「コードを編集」を選択してください。
data:image/s3,"s3://crabby-images/52780/52780cc345eb09f5ac48ae217b6334abf3980f8a" alt="「3点リーダー」をクリックし「コードを編集」を選択する参考画像"
「sections」フォルダを選択して開き、「新しいセクションを追加する」から任意の名前でパーツのliquidファイルを制作してください。ここでは「custom-slider.liquid」とします。
data:image/s3,"s3://crabby-images/436bf/436bfd81e0300de0941608172915cdb6c524d0e3" alt="custom-slider.liquidを作成する参考画像"
追加した「custom-slider.liquid」に以下のコードを貼り付けてください。
{%- style -%}
.section-{{ section.id }}-padding {
padding-top: calc({{ section.settings.padding_top }}px * 0.75);
padding-bottom: calc({{ section.settings.padding_bottom }}px * 0.75);
}
@media screen and (min-width: 750px) {
.section-{{ section.id }}-padding {
padding-top: {{ section.settings.padding_top }}px;
padding-bottom: {{ section.settings.padding_bottom }}px;
}
}
.swiper-wrapper {
transition-timing-function: linear;
img {
width: 100%;
height: 400px;
object-fit: cover;
}
}
@media screen and (max-width: 750px) {
.swiper-wrapper img {
height: 200px;
}
}
{%- endstyle -%}
<div class="color-{{ section.settings.color_scheme }} gradient">
<div class="section-{{ section.id }}-padding">
<div class="swiper">
<div class="swiper-wrapper">
<!-- Slides -->
{% for block in section.blocks %}
<div class="swiper-slide">
<img src="{{ block.settings.slide_img | image_url }}">
</div>
{% endfor %}
</div>
<div class="swiper-pagination"></div>
<div class="swiper-button-prev"></div>
<div class="swiper-button-next"></div>
</div>
</div>
</div>
{% schema %}
{
"name": "流れ続けるスライダー",
"tag": "section",
"settings": [
{
"type": "color_scheme",
"id": "color_scheme",
"label": "t:sections.all.colors.label",
"default": "scheme-1"
}, {
"type": "header",
"content": "t:sections.all.padding.section_padding_heading"
}, {
"type": "range",
"id": "padding_top",
"min": 0,
"max": 100,
"step": 4,
"unit": "px",
"label": "t:sections.all.padding.padding_top",
"default": 40
}, {
"type": "range",
"id": "padding_bottom",
"min": 0,
"max": 100,
"step": 4,
"unit": "px",
"label": "t:sections.all.padding.padding_bottom",
"default": 52
}
],
"blocks": [
{
"type": "slide1",
"name": "スライド1",
"settings": [
{
"type": "image_picker",
"label": "スライド画像",
"id": "slide_img"
}
]
},
{
"type": "slide2",
"name": "スライド2",
"settings": [
{
"type": "image_picker",
"label": "スライド画像",
"id": "slide_img"
}
]
},
{
"type": "slide3",
"name": "スライド3",
"settings": [
{
"type": "image_picker",
"label": "スライド画像",
"id": "slide_img"
}
]
},
{
"type": "slide4",
"name": "スライド4",
"settings": [
{
"type": "image_picker",
"label": "スライド画像",
"id": "slide_img"
}
]
}, {
"type": "slide5",
"name": "スライド5",
"settings": [
{
"type": "image_picker",
"label": "スライド画像",
"id": "slide_img"
}
]
}, {
"type": "slide6",
"name": "スライド6",
"settings": [
{
"type": "image_picker",
"label": "スライド画像",
"id": "slide_img"
}
]
}
],
"presets": [
{
"name": "流れ続けるスライダー",
"blocks": [
{
"type": "slide1"
},
{
"type": "slide2"
},
{
"type": "slide3"
},
{
"type": "slide4"
}, {
"type": "slide5"
}, {
"type": "slide6"
}
]
}
]
}
{% endschema %}
次に「aseets」フォルダから「animations.js」を選択し、最下部に下記のコードをコピペしてください。
//swiper
window.addEventListener('DOMContentLoaded', function () {
const swiper = new Swiper('.swiper', {
loop: true,
slidesPerView: 3,
speed: 3000,
allowTouchMove: false,
autoplay: {
delay: 0,
},
breakpoints: {
// 751px以上の場合
751: {
slidesPerView: 5,
},
},
});
});
data:image/s3,"s3://crabby-images/ea0d4/ea0d4c9b1126612fac34cfdf1cb4ffa7e5ff3f26" alt="「aseets」フォルダからanimations.jsを選択し、コードを貼り付けする参考画像"
次に「layout」から「theme.liquid」を開き、</body>の直前に以下のコードをコピペしてください。
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/swiper@11/swiper-bundle.min.css" />
<script src="https://cdn.jsdelivr.net/npm/swiper@11/swiper-bundle.min.js"></script>
data:image/s3,"s3://crabby-images/4a9b3/4a9b36ae8045b1b66dd8509c92c023bec2d068d5" alt="bodyの閉じタグの直前にコードを貼り付けする参考画像"
これでコードの追加は終了なので、右上の「保存ボタン」を押してください。
次にカスタマイズ画面で、「流れ続けるスライダー」を追加して各種画像を設定していきます。
オンラインストアの「テーマ」から「カスタマイズ」をクリックして、カスタマイズ画面に移動してください。
data:image/s3,"s3://crabby-images/80fb9/80fb991e1479f034bddd792b6e110f6239a90bc2" alt="テーマからカスタマイズをクリックして、カスタマイズ画面に移動する参考画像"
次に「セクションを追加」から「流れ続けるスライダー」を追加してください。
data:image/s3,"s3://crabby-images/4b822/4b822644138b78281141a9babb996ccc911f2d82" alt="カスタマイズ画面で、流れ続けるスライダーを追加する参考画像"
最後に各スライドを選択し、任意の画像を設定してください。
data:image/s3,"s3://crabby-images/239fe/239fe4555d2b47fd9d220714946bef0b8f746398" alt="各スライドの画像を設定する参考画像"
data:image/s3,"s3://crabby-images/4b695/4b695b79d765de3179a9d64dacace166f9fc4ebe" alt="Shopifyの無限スライダー(カルーセル)の完成イメージ"
これで完了です!お疲れさまでした!
さいごに
この記事では、Shopifyで流れ続けるスライダーを実装する方法を解説しました。
Shopifyでのサイト運営において、スライダーの実装は見た目を大きく改善できる重要な要素です。今回紹介した実装方法の重要ポイントは以下の通りです。
- セクションファイルの配置場所が正しいか確認する
- JavaScriptライブラリはbodyの閉じタグの前に読み込む
Shopifyでのサイト運営は一朝一夕にはいきませんが、一つ一つの改善を重ねることで、確実にサイトの質を高めることができます。
この記事で紹介した実装方法を参考に、ぜひご自身のサイトを改善してみてください。
関連記事
data:image/s3,"s3://crabby-images/57d5c/57d5c27ae708bde7afbed4c10ce3edebcebdf42f" alt=""
data:image/s3,"s3://crabby-images/f9a0e/f9a0e25e14bb5f1199be4cfa0e891a52fa0f9b02" alt=""