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
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>
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>
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>
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>
在上述代码中,我们首先导入Slider组件,然后在模板中使用<slider></slider>
this.$emit('change', this.value);
. 4. Penggunaan komponenSelepas 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!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



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

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.

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.

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.

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.

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.

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.

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.
