Rumah hujung hadapan web View.js Bagaimana untuk melaksanakan komponen karusel menggunakan Vue?

Bagaimana untuk melaksanakan komponen karusel menggunakan Vue?

Jun 25, 2023 am 09:13 AM
vue komponen karusel

Dengan populariti peranti mudah alih, komponen karusel telah menjadi bahagian yang sangat diperlukan dalam banyak projek bahagian hadapan. Dalam artikel ini, kami akan memperkenalkan langkah demi langkah cara melaksanakan komponen karusel mudah menggunakan Vue.

  1. Memulakan projek Vue

Gunakan Vue-cli untuk memulakan projek Vue baharu dan memasang perpustakaan bergantung:

vue create slideshow
cd slideshow
npm install --save vue-router vue-awesome-swiper
Salin selepas log masuk

Antaranya, vue-router ialah perpustakaan penghalaan yang disediakan secara rasmi oleh Vue , vue-awesome-swiper ialah pemalam Swiper berkapsul Vue. vue-router 是 Vue 官方提供的路由库,vue-awesome-swiper 是一个 Vue 封装的 Swiper 插件。

  1. 创建轮播图组件

src 目录下创建一个名为 components 的文件夹,在其中创建名为 Slideshow.vue 的组件文件:

<template>
  <div class="swiper-container">
    <div class="swiper-wrapper">
      <div class="swiper-slide" v-for="item in list" :key="item.id">
        <img :src="item.src" alt="item.title" />
      </div>
    </div>
    <div class="swiper-pagination"></div>
    <div class="swiper-button-next"></div>
    <div class="swiper-button-prev"></div>
  </div>
</template>

<script>
import Swiper from 'vue-awesome-swiper';
import 'swiper/css/swiper.css';

export default {
  name: 'Slideshow',
  props: {
    list: {
      type: Array,
      default: () => [],
    },
  },
  components: {
    Swiper,
  },
  mounted() {
    this.initSwiper();
  },
  methods: {
    initSwiper() {
      new Swiper('.swiper-container', {
        loop: true,
        autoplay: {
          disableOnInteraction: false,
          delay: 3000,
        },
        pagination: {
          el: '.swiper-pagination',
          clickable: true,
        },
        navigation: {
          nextEl: '.swiper-button-next',
          prevEl: '.swiper-button-prev',
        },
      });
    },
  },
};
</script>

<style lang="scss">
.swiper-container {
  width: 100%;
  height: 100%;
  .swiper-pagination {
    position: absolute;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%);
  }
  .swiper-button-next,
  .swiper-button-prev {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 30px;
    height: 30px;
    cursor: pointer;
    z-index: 20;
    background-color: rgba(0, 0, 0, 0.3);
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .swiper-button-next:hover,
  .swiper-button-prev:hover {
    background-color: rgba(0, 0, 0, 0.6);
  }
  .swiper-button-next {
    right: 20px;
  }
  .swiper-button-prev {
    left: 20px;
  }
}
</style>
Salin selepas log masuk

在该组件中,我们使用了 vue-awesome-swiper 插件来实现轮播图效果。在 props 中定义了 list 属性,用于接收轮播图数据。在 mounted 钩子中调用了 initSwiper 方法,用来初始化轮播图。

  1. 使用轮播图组件

App.vue 文件中,我们可以使用刚才创建的轮播图组件:

<template>
  <div id="app">
    <slideshow :list="slideshowList" />
  </div>
</template>

<script>
import Slideshow from './components/Slideshow.vue';

export default {
  name: 'App',
  components: {
    Slideshow,
  },
  data() {
    return {
      slideshowList: [
        { id: 1, src: require('./assets/slideshow1.jpg'), title: '轮播图1' },
        { id: 2, src: require('./assets/slideshow2.jpg'), title: '轮播图2' },
        { id: 3, src: require('./assets/slideshow3.jpg'), title: '轮播图3' },
      ],
    };
  },
};
</script>

<style>
#app {
  text-align: center;
}
</style>
Salin selepas log masuk

data 中定义了一个数组 slideshowList,用来存放轮播图的数据。在模板中,我们使用自定义标签 slideshow 来引用轮播图组件,并将 slideshowList

    Buat komponen karusel

    🎜Buat folder bernama komponen dalam direktori src dan buat folder bernama fail Komponen Slideshow.vue: 🎜rrreee🎜Dalam komponen ini, kami menggunakan pemalam vue-awesome-swiper untuk mencapai kesan karusel. Atribut list ditakrifkan dalam props dan digunakan untuk menerima data imej karusel. Kaedah initSwiper dipanggil dalam cangkuk mounted untuk memulakan imej karusel. 🎜
      🎜Gunakan komponen karusel🎜🎜🎜Dalam fail App.vue, kita boleh menggunakan komponen karusel yang baru kita buat: 🎜rrreee🎜Dalam Tatasusunan <code>slideshowList ditakrifkan dalam data untuk menyimpan data imej karusel. Dalam templat, kami menggunakan teg tersuai show slaid untuk merujuk komponen karusel dan menghantar slideshowList kepada komponen. 🎜🎜Pada ketika ini, kami telah berjaya melaksanakan komponen karusel menggunakan Vue. Melalui contoh ini, kita boleh melihat idea komponen Vue dan penggunaan suntikan pergantungan, serta cara menggunakan pemalam pihak ketiga untuk mencapai beberapa kesan yang kompleks. Dengan melaksanakan sendiri komponen karusel, kami juga boleh mempunyai pemahaman yang lebih mendalam tentang kitaran hayat dan cangkuk Vue. 🎜

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan komponen karusel menggunakan Vue?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Kenapa tidak ada maklumat permintaan halaman di rangkaian konsol selepas melompat Vue-router? Kenapa tidak ada maklumat permintaan halaman di rangkaian konsol selepas melompat Vue-router? Apr 04, 2025 pm 05:27 PM

Kenapa tidak ada maklumat permintaan halaman di rangkaian konsol selepas melompat Vue-router? Apabila menggunakan Vue-Router untuk pengalihan halaman, anda mungkin melihat ...

Bagaimana cara menggunakan Vue untuk melaksanakan borang petikan elektronik dengan header tunggal dan berbilang badan? Bagaimana cara menggunakan Vue untuk melaksanakan borang petikan elektronik dengan header tunggal dan berbilang badan? Apr 04, 2025 pm 11:39 PM

Cara melaksanakan borang petikan elektronik dengan header tunggal dan berbilang badan dalam Vue. Dalam pengurusan perusahaan moden, pemprosesan elektronik borang petikan adalah untuk meningkatkan kecekapan dan ...

Bagaimana untuk melaksanakan fungsi memuat naik foto ahli-ahli fotografi tinggi jenama yang berbeza di hujung depan? Bagaimana untuk melaksanakan fungsi memuat naik foto ahli-ahli fotografi tinggi jenama yang berbeza di hujung depan? Apr 04, 2025 pm 05:42 PM

Bagaimana untuk melaksanakan fungsi memuat naik foto jenama-jenama ahli fotografi yang berbeza di hujung depan apabila membangunkan projek-projek front-end, anda sering menghadapi keperluan untuk mengintegrasikan peralatan perkakasan. untuk ...

Bagaimana untuk mencapai kesan segmentasi dengan sempadan lengkung 45 darjah? Bagaimana untuk mencapai kesan segmentasi dengan sempadan lengkung 45 darjah? Apr 04, 2025 pm 11:48 PM

Petua untuk melaksanakan kesan segmen dalam reka bentuk antara muka pengguna, Segmenter adalah elemen navigasi biasa, terutamanya dalam aplikasi mudah alih dan laman web responsif. …

Bagaimana cara menggunakan El-Table untuk melaksanakan pengelompokan meja, seret dan drop penyortiran di VUE2? Bagaimana cara menggunakan El-Table untuk melaksanakan pengelompokan meja, seret dan drop penyortiran di VUE2? Apr 04, 2025 pm 07:54 PM

Melaksanakan El-Table Table Group Drag dan Drop Sorting di VUE2. Menggunakan jadual el-meja untuk melaksanakan seretan kumpulan dan penyortiran drop dalam VUE2 adalah keperluan biasa. Katakan kita mempunyai ...

Bagaimana untuk memastikan bahagian bawah objek 3D ditetapkan pada peta menggunakan Mapbox dan Three.js di Vue? Bagaimana untuk memastikan bahagian bawah objek 3D ditetapkan pada peta menggunakan Mapbox dan Three.js di Vue? Apr 04, 2025 pm 06:42 PM

Cara menggunakan Mapbox dan Three.js di Vue untuk menyesuaikan objek tiga dimensi untuk memetakan sudut tontonan. Apabila menggunakan Vue untuk menggabungkan Mapbox dan Three.js, objek tiga dimensi yang dicipta perlu ...

Adakah JavaScript Menamakan Spesifikasi Meningkatkan Isu Keserasian di Android Webview? Adakah JavaScript Menamakan Spesifikasi Meningkatkan Isu Keserasian di Android Webview? Apr 04, 2025 pm 07:15 PM

Spesifikasi Penamaan JavaScript dan Android ...

See all articles