


Bagaimana untuk melaksanakan fungsi drag-and-drop dan pengisihan imej melalui Vue?
Bagaimana untuk melaksanakan fungsi seret dan lepas dan mengisih imej melalui Vue?
Vue, sebagai rangka kerja JavaScript yang popular, menyediakan fungsi berkuasa untuk mengendalikan antara muka pengguna. Dalam artikel ini, kita akan belajar cara menggunakan Vue untuk melaksanakan fungsi menyeret dan menyusun imej.
Mula-mula, kita perlu memasang Vue dan mencipta contoh Vue. Kita boleh memasang Vue melalui arahan berikut:
npm install vue
Seterusnya, cipta fail HTML, perkenalkan kebergantungan Vue dan buat contoh Vue:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Drag and Sort Images</title> <script src="https://cdn.jsdelivr.net/npm/vue"></script> </head> <body> <div id="app"> <div class="image-container"> <div class="image-card" v-for="(image, index) in images" :key="index" :style="{left: image.x + 'px', top: image.y + 'px'}" @mousedown="startDrag(index)" @mouseup="stopDrag(index)" @mousemove="drag(index)"> <img src="/static/imghwm/default1.png" data-src="image.src" class="lazy" : alt="Image"> </div> </div> </div> <script> new Vue({ el: '#app', data: { images: [ { src: 'image1.jpg', x: 0, y: 0 }, { src: 'image2.jpg', x: 0, y: 0 }, { src: 'image3.jpg', x: 0, y: 0 }, { src: 'image4.jpg', x: 0, y: 0 } ], dragging: false, draggedIndex: -1, initialX: 0, initialY: 0 }, methods: { startDrag(index) { this.dragging = true; this.draggedIndex = index; this.initialX = event.clientX; this.initialY = event.clientY; }, stopDrag(index) { if (this.dragging && this.draggedIndex !== -1) { this.images.splice(index, 0, this.images.splice(this.draggedIndex, 1)[0]); } this.dragging = false; this.draggedIndex = -1; }, drag(index) { if (this.dragging && this.draggedIndex !== -1) { const dx = event.clientX - this.initialX; const dy = event.clientY - this.initialY; this.images[index].x += dx; this.images[index].y += dy; this.initialX = event.clientX; this.initialY = event.clientY; } } } }); </script> </body> </html>
Kod di atas akan mencipta bekas imej dengan fungsi seret dan lepas dan pengisihan. Kami menggunakan arahan v-for
untuk lelaran melalui tatasusunan imej
dan menggunakan arahan v-bind
untuk mengikat kedudukan setiap imej kepada gaya CSS. v-for
指令来遍历images
数组,并使用v-bind
指令将每个图片的位置绑定到CSS样式上。
在Vue实例的data
属性中,我们定义了一个images
数组,每个元素包含src
、x
和y
属性。dragging
、draggedIndex
、initialX
和initialY
属性用于跟踪拖拽的状态和初始位置。
startDrag
方法在鼠标按下时设置拖拽状态,并记录初始位置。
stopDrag
方法在鼠标松开时停止拖拽,并根据拖拽的位置进行数组排序。
drag
方法在鼠标移动时更新图片的位置。
以上代码实现了基本的拖拽和排序功能,但还可以进一步改进。
我们可以添加限制条件,使图片只能在容器范围内移动。为此,我们可以修改drag
data
contoh Vue, kami mentakrifkan tatasusunan imej
, setiap elemen mengandungi src
, x code > dan atribut <code>y
. Sifat dragging
, draggedIndex
, initialX
dan initialY
digunakan untuk menjejak status dan kedudukan awal penyeretan. Kaedah startDrag
menetapkan keadaan seret apabila tetikus ditekan dan merekodkan kedudukan awal. KaedahstopDrag
berhenti menyeret apabila tetikus dilepaskan dan mengisih tatasusunan mengikut kedudukan yang diseret. 🎜🎜 Kaedahdrag
mengemas kini kedudukan imej apabila tetikus bergerak. 🎜🎜Kod di atas melaksanakan fungsi seret dan lepas dan pengisihan asas, tetapi ia boleh dipertingkatkan lagi. 🎜🎜Kami boleh menambah sekatan supaya imej hanya boleh dialihkan dalam bekas. Untuk tujuan ini, kita boleh mengubah suai kaedah drag
seperti berikut: 🎜drag(index) { if (this.dragging && this.draggedIndex !== -1) { const dx = event.clientX - this.initialX; const dy = event.clientY - this.initialY; const container = document.querySelector('.image-container'); const containerRect = container.getBoundingClientRect(); const imageRect = event.target.getBoundingClientRect(); if ( imageRect.left + dx >= containerRect.left && imageRect.right + dx <= containerRect.right && imageRect.top + dy >= containerRect.top && imageRect.bottom + dy <= containerRect.bottom ) { this.images[index].x += dx; this.images[index].y += dy; this.initialX = event.clientX; this.initialY = event.clientY; } } }🎜Dengan cara ini, imej hanya boleh diseret dan dialihkan dalam julat bekas. 🎜🎜Dengan contoh kod ringkas ini, kami mempelajari cara menggunakan Vue untuk melaksanakan fungsi seret dan lepas dan isihan imej. Dalam projek sebenar, anda boleh menambah baik dan mengembangkan fungsi ini mengikut keperluan anda sendiri. 🎜
Atas ialah kandungan terperinci Bagaimana untuk melaksanakan fungsi drag-and-drop dan pengisihan imej melalui Vue?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Netflix terutamanya menganggap prestasi, skalabiliti, kecekapan pembangunan, ekosistem, hutang teknikal dan kos penyelenggaraan dalam pemilihan rangka kerja. 1. Prestasi dan Skalabiliti: Java dan Springboot dipilih untuk memproses data besar -besaran dan permintaan serentak yang tinggi. 2. Kecekapan Pembangunan dan Ekosistem: Gunakan React untuk meningkatkan kecekapan pembangunan front-end dan menggunakan ekosistemnya yang kaya. 3. Hutang Teknikal dan Penyelenggaraan Kos: Pilih Node.js untuk membina mikroservis untuk mengurangkan kos penyelenggaraan dan hutang teknikal.

Netflix terutamanya menggunakan React sebagai rangka kerja front-end, ditambah dengan VUE untuk fungsi tertentu. 1) Komponen React dan DOM maya meningkatkan prestasi dan kecekapan pembangunan aplikasi Netflix. 2) VUE digunakan dalam alat dalaman dan projek kecil Netflix, dan fleksibiliti dan kemudahan penggunaannya adalah kunci.

Vue.js adalah rangka kerja JavaScript yang progresif yang sesuai untuk membina antara muka pengguna yang kompleks. 1) Konsep terasnya termasuk data responsif, komponen dan DOM maya. 2) Dalam aplikasi praktikal, ia boleh ditunjukkan dengan membina aplikasi todo dan mengintegrasikan vuerouter. 3) Apabila debugging, disyorkan untuk menggunakan Vuedevtools dan Console.log. 4) Pengoptimuman prestasi boleh dicapai melalui V-IF/V-Show, senarai pengoptimuman rendering, pemuatan asynchronous komponen, dll.

Vue.js sesuai untuk projek kecil dan sederhana, sementara React lebih sesuai untuk aplikasi besar dan kompleks. 1. Sistem responsif vue.js secara automatik mengemas kini DOM melalui pengesanan ketergantungan, menjadikannya mudah untuk menguruskan perubahan data. 2. Leact mengamalkan aliran data sehala, dan data mengalir dari komponen induk ke komponen kanak-kanak, menyediakan aliran data yang jelas dan struktur yang mudah dibuang.

Vue.js sesuai untuk projek kecil dan sederhana dan lelaran yang cepat, sementara React sesuai untuk aplikasi besar dan kompleks. 1) Vue.js mudah digunakan dan sesuai untuk situasi di mana pasukan tidak mencukupi atau skala projek kecil. 2) React mempunyai ekosistem yang lebih kaya dan sesuai untuk projek dengan prestasi tinggi dan keperluan fungsional yang kompleks.

Kaedah untuk melaksanakan lompatan tag dalam Vue termasuk: menggunakan tag dalam templat HTML untuk menentukan atribut HREF. Gunakan komponen router-link routing VUE. Gunakan ini. $ Router.push () kaedah dalam JavaScript. Parameter boleh dilalui melalui parameter pertanyaan dan laluan dikonfigurasikan dalam pilihan penghala untuk lompatan dinamik.

Terdapat kaedah berikut untuk melaksanakan lompat komponen di Vue: Gunakan Router-Link dan & lt; Router-View & GT; Komponen untuk melaksanakan lompat hiperpautan, dan tentukan: untuk atribut sebagai laluan sasaran. Gunakan & lt; router-view & gt; Komponen secara langsung untuk memaparkan komponen yang dijalankan yang sedang dialihkan. Gunakan kaedah router.push () dan router.replace () untuk navigasi programatik. Bekas menjimatkan sejarah dan yang kedua menggantikan laluan semasa tanpa meninggalkan rekod.

Terdapat dua cara untuk melompat elemen div di Vue: Gunakan Vue Router dan tambahkan komponen router-link. Tambah pendengar acara @Click dan panggil ini. $ Router.push () kaedah untuk melompat.


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

mPDF
mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),

Versi Mac WebStorm
Alat pembangunan JavaScript yang berguna

VSCode Windows 64-bit Muat Turun
Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

EditPlus versi Cina retak
Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

MantisBT
Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.