Jadual Kandungan
1. Analisis Keperluan
2. Persediaan pembangunan
3. Pembangunan komponen
Templat:
Gaya:
Logik:
四、组件使用
Rumah hujung hadapan web View.js Vue dalam tindakan: pembangunan komponen gelangsar

Vue dalam tindakan: pembangunan komponen gelangsar

Nov 24, 2023 am 09:24 AM
vue Pertempuran sebenar Komponen peluncur

Vue dalam tindakan: pembangunan komponen gelangsar

Vue dalam tindakan: Pembangunan komponen Slider

Pengenalan: Komponen Slider ialah salah satu komponen interaksi pengguna biasa dan digunakan secara meluas dalam halaman web, aplikasi mudah alih dan aplikasi desktop. Artikel ini akan melaksanakan komponen peluncur mudah melalui rangka kerja Vue untuk membantu pembaca memahami cara membangunkan komponen tersuai dan menunjukkan proses pelaksanaan melalui contoh kod tertentu.

1. Analisis Keperluan

Komponen gelangsar yang ingin kita bangunkan mempunyai fungsi berikut:

  • Gelangsar boleh seret: Pengguna boleh menyeret gelangsar dengan tetikus, dan kedudukan gelangsar akan ditukar apabila gelongsor
  • Paparan nilai: Nilai yang diwakili oleh peluncur perlu dipaparkan dalam masa nyata di sebelah penggelongsor
  • Fungsi panggil balik: Apabila nilai penggelongsor berubah, fungsi panggil balik mesti dilaksanakan.

2. Persediaan pembangunan

Sebelum mula membangunkan komponen slider, kita perlu memastikan bahawa persekitaran pembangunan Vue telah dipasang dan mencipta projek.

# 安装Vue开发环境
$ npm install vue

# 创建Vue项目
$ vue create slider-demo
Salin selepas log masuk

3. Pembangunan komponen

Seterusnya, kita mula menulis kod untuk komponen gelangsar. Mula-mula, buat fail Slider.vue dalam direktori src/components dan tulis templat, gaya dan logik komponen di dalamnya.

Templat:

<template>
  <div class="slider-wrapper">
    <div class="slider" :style="sliderStyle" @mousedown="handleMouseDown" @mousemove="handleMouseMove" @mouseup="handleMouseUp"></div>
    <div class="value">{{ value }}</div>
  </div>
</template>
Salin selepas log masuk

Dalam templat, kami menggunakan .slider-wrapper luar, yang mengandungi .slider untuk memaparkan slider dan menggunakan arahan :value untuk mengikat kedudukan slider (melalui pelaksanaan Computed property sliderStyle) , dan terdapat juga .value yang digunakan untuk memaparkan nilai yang diwakili oleh peluncur.

Gaya:

<style scoped>
.slider-wrapper {
  position: relative;
  width: 400px;
  height: 40px;
  background-color: #eee;
  border-radius: 20px;
  margin: 20px;
}
.slider {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  background-color: #007bff;
  border-radius: 50%;
  cursor: pointer;
}
.value {
  position: absolute;
  top: 50%;
  left: 50px;
  transform: translateY(-50%);
  font-size: 16px;
}
</style>
Salin selepas log masuk

Dalam gaya, kami menambah gaya yang diperlukan untuk komponen peluncur dan paparan berangka, dan menetapkan lebar, ketinggian, warna latar belakang, sudut bulat, dll. bekas.

Logik:

<script>
export default {
  name: 'Slider',
  data() {
    return {
      isDragging: false,
      value: 50,
      sliderStyle: {
        left: 'calc(' + this.value + '% - 10px)'
      }
    }
  },
  methods: {
    handleMouseDown() {
      this.isDragging = true;
    },
    handleMouseMove(event) {
      if (this.isDragging) {
        const rect = this.$el.getBoundingClientRect();
        const offsetX = event.clientX - rect.left;
        const newValue = Math.round(offsetX / rect.width * 100);
        this.value = Math.max(0, Math.min(newValue, 100));
        this.sliderStyle.left = 'calc(' + this.value + '% - 10px)';
        this.$emit('change', this.value);
      }
    },
    handleMouseUp() {
      this.isDragging = false;
    }
  }
}
</script>
Salin selepas log masuk

Dalam bahagian logik, kami mentakrifkan data awal komponen, termasuk sama ada ia menyeret (isDragging), nilai awal peluncur (nilai), dan gaya peluncur (sliderStyle). Antaranya, kedudukan peluncur dilaksanakan menggunakan sifat terkira, dikira melalui margin kiri: left: 'calc(' + this.value + '% - 10px)'. left: 'calc(' + this.value + '% - 10px)'

此外,我们还实现了三个方法:handleMouseDown用于鼠标按下时改变isDragging的值,handleMouseMove用于鼠标移动时计算滑块位置、更新滑块数值并触发change事件,handleMouseUp用于鼠标松开时改变isDragging的值。

最后,我们通过this.$emit('change', this.value);来触发change事件并传递滑块的数值。

四、组件使用

在完成组件的开发后,我们可以在其他页面中使用该滑块组件。

<template>
  <div>
    <Slider @change="handleChange" />
  </div>
</template>

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

export default {
  name: 'App',
  components: {
    Slider
  },
  methods: {
    handleChange(value) {
      console.log('滑块数值发生变化:', value);
    }
  }
}
</script>
Salin selepas log masuk

在上述代码中,我们首先导入Slider组件,然后在模板中使用<slider></slider>

Selain itu, kami juga telah melaksanakan tiga kaedah: handleMouseDown digunakan untuk menukar nilai isDragging apabila tetikus ditekan, handleMouseMove digunakan untuk mengira kedudukan slider, mengemas kini nilai slider dan mencetuskan peristiwa perubahan apabila tetikus digerakkan , handleMouseUp digunakan untuk melepaskan tetikus apabila menukar nilai isDragging.

Akhir sekali, kami mencetuskan peristiwa perubahan dan menghantar nilai peluncur melalui this.$emit('change', this.value);.

4. Penggunaan komponen

Selepas selesai pembangunan komponen, kita boleh menggunakan komponen slider di halaman lain. 🎜rrreee🎜Dalam kod di atas, kami mula-mula mengimport komponen Slider, dan kemudian menggunakan komponen dalam templat menggunakan <slider></slider>. Pada masa yang sama, kami menentukan kaedah handleChange untuk mengendalikan fungsi panggil balik apabila nilai peluncur berubah. 🎜🎜5. Ringkasan🎜🎜Melalui contoh kod di atas, kami telah berjaya membangunkan komponen peluncur mudah dan menggunakannya pada halaman lain. Melalui contoh ini, kami belajar cara menggunakan rangka kerja Vue untuk membangunkan komponen tersuai, melaksanakan fungsi menyeret peluncur melalui fungsi cangkuk (mousedown, mousemove, mouseup), dan cara menggunakan sifat terkira untuk mengemas kini kedudukan slider secara nyata. masa. 🎜🎜Sudah tentu, ini hanyalah contoh mudah, dan fungsi dan pemprosesan gaya yang lebih kompleks mungkin diperlukan dalam pembangunan sebenar. Walau bagaimanapun, melalui panduan artikel ini, saya berharap pembaca dapat menguasai kaedah pembangunan komponen tersuai di bawah rangka kerja Vue dan dapat mengembangkan dan mengoptimumkannya dalam projek sebenar. Saya doakan anda semua lebih berjaya dalam pembangunan Vue! 🎜

Atas ialah kandungan terperinci Vue dalam tindakan: pembangunan komponen gelangsar. 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)

Cara menambah fungsi ke butang untuk vue Cara menambah fungsi ke butang untuk vue Apr 08, 2025 am 08:51 AM

Anda boleh menambah fungsi ke butang VUE dengan mengikat butang dalam templat HTML ke kaedah. Tentukan kaedah dan tulis logik fungsi dalam contoh Vue.

Cara menggunakan bootstrap di vue Cara menggunakan bootstrap di vue Apr 07, 2025 pm 11:33 PM

Menggunakan bootstrap dalam vue.js dibahagikan kepada lima langkah: Pasang bootstrap. Import bootstrap di main.js. Gunakan komponen bootstrap secara langsung dalam templat. Pilihan: Gaya tersuai. Pilihan: Gunakan pemalam.

Cara Menggunakan Watch di Vue Cara Menggunakan Watch di Vue Apr 07, 2025 pm 11:36 PM

Pilihan Watch di Vue.js membolehkan pemaju mendengar perubahan dalam data tertentu. Apabila data berubah, tontonkan mencetuskan fungsi panggil balik untuk melakukan paparan kemas kini atau tugas lain. Pilihan konfigurasinya termasuk segera, yang menentukan sama ada untuk melaksanakan panggilan balik dengan serta -merta, dan mendalam, yang menentukan sama ada untuk mendengarkan secara rekursif terhadap objek atau tatasusunan.

Cara merujuk fail js dengan vue.js Cara merujuk fail js dengan vue.js Apr 07, 2025 pm 11:27 PM

Terdapat tiga cara untuk merujuk kepada fail JS dalam vue.js: Secara langsung tentukan jalan menggunakan & lt; skrip & gt; tag ;; import dinamik menggunakan cangkuk kitaran hayat yang dipasang (); dan mengimport melalui Perpustakaan Pengurusan Negeri VUEX.

Apakah yang dimaksudkan dengan pembangunan Vue Multi-Page? Apakah yang dimaksudkan dengan pembangunan Vue Multi-Page? Apr 07, 2025 pm 11:57 PM

Pembangunan pelbagai halaman Vue adalah cara untuk membina aplikasi menggunakan rangka kerja VUE.JS, di mana permohonan dibahagikan kepada halaman berasingan: Penyelenggaraan kod: Memisahkan aplikasi ke dalam beberapa halaman boleh menjadikan kod lebih mudah untuk dikendalikan dan diselenggarakan. Modularity: Setiap halaman boleh digunakan sebagai modul yang berasingan untuk penggunaan semula dan penggantian mudah. Routing mudah: Navigasi antara halaman boleh diuruskan melalui konfigurasi penghalaan mudah. Pengoptimuman SEO: Setiap halaman mempunyai URL sendiri, yang membantu SEO.

Cara kembali ke halaman sebelumnya oleh Vue Cara kembali ke halaman sebelumnya oleh Vue Apr 07, 2025 pm 11:30 PM

Vue.js mempunyai empat kaedah untuk kembali ke halaman sebelumnya: $ router.go (-1) $ router.back () menggunakan & lt; router-link to = & quot;/& quot; Komponen Window.History.Back (), dan pemilihan kaedah bergantung pada tempat kejadian.

Cara Menanyakan Versi Vue Cara Menanyakan Versi Vue Apr 07, 2025 pm 11:24 PM

Anda boleh menanyakan versi VUE dengan menggunakan Vue Devtools untuk melihat tab VUE dalam konsol penyemak imbas. Gunakan NPM untuk menjalankan arahan "NPM LIST -G VUE". Cari item VUE dalam objek "Dependencies" fail Package.json. Untuk projek Vue CLI, jalankan perintah "Vue -version". Semak maklumat versi di & lt; skrip & gt; Tag dalam fail HTML yang merujuk kepada fail VUE.

Cara Menggunakan Fungsi Memintas Vue Cara Menggunakan Fungsi Memintas Vue Apr 08, 2025 am 06:51 AM

Pemintasan fungsi dalam VUE adalah teknik yang digunakan untuk mengehadkan bilangan kali fungsi dipanggil dalam tempoh masa yang ditentukan dan mencegah masalah prestasi. Kaedah pelaksanaan adalah: mengimport perpustakaan lodash: import {debounce} dari 'lodash'; Gunakan fungsi debounce untuk membuat fungsi memintas: const debouncedfunction = debounce (() = & gt; { / logical /}, 500); Panggil fungsi Intercept, dan fungsi kawalan dipanggil paling banyak sekali dalam 500 milisaat.

See all articles