HTML5 实现页面图片的拖拉效果

这篇博客介绍如何使用HTML5实现图片在页面不同区域间的拖放效果。通过设置dragstart、dragover和drop事件,可以允许用户将图片从一个div拖放到另一个div中,实现图片的动态移动。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

页面分为上下两个div,div1中放置一张图片,可实现拖拽至div2中,代码为了省事,全放入html文件,

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <title></title>
        <style type="text/css">
            mark{
                background-color: red;
            }
        </style>
        <script src="js/jquery-3.5.1.min.js" type="text/javascript" charset="utf-8"></script>
    </head>
    <body>

        <!-- 宽和高根据图片大小进行设定 -->
        <div id="box1" style="border: 1px solid black;width: 550px; height: 300px;">
            <img id="img1" src="img/1.jpg" draggable="true" />
        </div>
        <div id="box2" style="border: 1px solid black;width: 550px; height: 300px;">
            
        </div>
        <script type="text/javascript" charset="utf-8">
            window.onload = function(){
                var box1 = document.getElementById("box1")
                var box2 = document.getElementById("box2")
                var img1 = document.getElementById("img1")
                //box1的图片拖放到box2
                //设置想拖放的内容
                img1.ondragstart = function(e){
                    var data = e.dataTransfer
                    data.setData("text/plain",this.id)
                }
                //设置目标元素允许接受拖放元素
                box2.ondragover = function(e){
                    e.preventDefault()
                }
                //取出拖放的内容
                box2.ondrop = function(e){
                    var data = e.dataTransfer
                    var text = data.getData("text/plain")
                    //插入
                    e.target.appendChild(document.getElementById(text))
                }
                //box2的内容拖到box1
                box1.ondragover = function(e){
                    e.preventDefault()
                }
                box1.ondrop = function(e){
                    var data = e.dataTransfer
                    var text = data.getData("text/plain")
                    //插入
                    e.target.appendChild(document.getElementById(text))
                }
            }
            
        </script>
    </body>
</html>

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值