Rumah > hujung hadapan web > Soal Jawab bahagian hadapan > pelaksanaan seret tetikus jquery

pelaksanaan seret tetikus jquery

PHPz
Lepaskan: 2023-05-23 16:20:37
asal
1082 orang telah melayarinya

jQuery ialah perpustakaan JavaScript popular yang boleh memanipulasi DOM dengan mudah untuk melaksanakan fungsi seret dan lepas tetikus. Dalam artikel ini, kami akan memperkenalkan secara terperinci cara menggunakan jQuery untuk melaksanakan fungsi seret tetikus.

  1. Pertama, masukkan perpustakaan jQuery dalam fail HTML anda. Anda boleh memuat turunnya dari tapak web rasmi jQuery atau gunakan CDN:
<script src="https://code.jquery.com/jquery-3.4.1.min.js"></script>
Salin selepas log masuk
  1. Buat elemen dalam fail HTML, seperti div:
<div id="dragElement">这是一个可拖拽的元素。</div>
Salin selepas log masuk
  1. Gunakan CSS menetapkan gaya asas elemen, seperti lebar, tinggi, warna latar belakang, dll.:
<style>
    #dragElement {
        width: 100px;
        height: 100px;
        background-color: yellow;
        position: absolute;
        left: 50%;
        top: 50%;
        margin-left: -50px;
        margin-top: -50px;
    }
</style>
Salin selepas log masuk
  1. Gunakan jQuery untuk menulis fungsi seret dan lepas:
$(function() {
    var isDragging = false;
    var currentX;
    var currentY;
    var initialX;
    var initialY;
    var xOffset = 0;
    var yOffset = 0;
    
    $('#dragElement').mousedown(function(e) {
        initialX = e.clientX - xOffset;
        initialY = e.clientY - yOffset;

        if (e.target === this) {
            isDragging = true;
        }
    });

    $(document).mousemove(function(e) {
        if (isDragging) {
            e.preventDefault();

            currentX = e.clientX - initialX;
            currentY = e.clientY - initialY;

            xOffset = currentX;
            yOffset = currentY;

            setTranslate(currentX, currentY, $('#dragElement'));
        }
    });

    $(document).mouseup(function(e) {
        initialX = currentX;
        initialY = currentY;

        isDragging = false;
    });

    function setTranslate(xPos, yPos, el) {
        el.css('transform', 'translate3d(' + xPos + 'px, ' + yPos + 'px, 0)');
    }
});
Salin selepas log masuk
  1. Jadikan elemen boleh diseret menggunakan CSS:
<style>
    #dragElement {
        cursor: move;
    }
</style>
Salin selepas log masuk
  1. Akhir sekali, anda boleh menguji kefungsian seretan anda berfungsi dengan betul. Cuba tahan butang kiri tetikus dan gerakkan tetikus untuk menyeret elemen.

Fungsi seret dalam kod di atas termasuk langkah berikut:

a. Dapatkan kedudukan awal elemen dan koordinat tetikus semasa apabila tetikus ditekan.

b. Semasa tetikus bergerak, hitung offset elemen dan gunakannya pada kedudukan elemen.

c. Apabila tetikus dilepaskan, rekod kedudukan akhir elemen.

d. Fungsi setTranslate menggunakan kedudukan pada elemen.

Kesimpulan

Menyeret tetikus boleh menjadikan tapak web lebih boleh digunakan dan mesra pengguna, dan ia merupakan kaedah interaksi asas. Menggunakan jQuery untuk melaksanakan fungsi seret tetikus adalah sangat mudah dan hanya memerlukan beberapa baris kod JavaScript. Semoga artikel ini membantu anda memahami cara melaksanakan fungsi ini dan menggunakannya dalam tapak web anda.

Atas ialah kandungan terperinci pelaksanaan seret tetikus jquery. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan