拖拽改变div大小(兼容移动端)

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">

<html>

 

<head>

  <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

  <title>拖拽改变大小(兼容移动端)</title>

  <script type="text/javascript" src="http://www.jq22.com/jquery/jquery-1.10.2.js"></script>

  <!--     <link rel="stylesheet" href="http://code.jquery.com/ui/1.10.3/themes/smoothness/jquery-ui.css"> -->

  <script type="text/javascript">

    /*

    * jQuery.Resize by Own

    * Date:2014.01.08

    */

    $(function () {

      var target = document.querySelector('#resizeable');

      //初始化参数

      var els = target.style,

        //鼠标的 X 和 Y 轴坐标

        x = y = 0;

      //绑定需要拖拽改变大小的元素对象 -----pc端---

      bindResize(target);

      //  移动端拖拽 -------------------

      // 手指按下

      target.addEventListener('touchstart', function (e) {

        x = e.targetTouches[0].pageX - target.offsetWidth,

          y = e.targetTouches[0].pageY - target.offsetHeight;

        e.preventDefault()

      });

      target.addEventListener('touchmove', function (e) {

        //运算中...

        els.width = e.targetTouches[0].pageX - x + 'px',

          els.height = e.targetTouches[0].pageY - y + 'px'

      })

    });

    function bindResize(el) {

 

      var els = el.style,

        //鼠标的 X 和 Y 轴坐标

        x = y = 0;

      //鼠标按下事件

      $(el).mousedown(function (e) {

        //按下元素后,计算当前鼠标与对象计算后的坐标

        x = e.clientX - el.offsetWidth,

          y = e.clientY - el.offsetHeight;

        //在支持 setCapture 做些东东

        el.setCapture ? (

          //捕捉焦点

          el.setCapture(),

          //设置事件

          el.onmousemove = function (ev) {

            mouseMove(ev || event)

          },

          el.onmouseup = mouseUp

        ) : (

            //绑定事件

            $(document).bind("mousemove", mouseMove).bind("mouseup", mouseUp)

          )

        //防止默认事件发生

        e.preventDefault()

      });

      //移动事件

      function mouseMove(e) {

        //运算中...

        els.width = e.clientX - x + 'px',

          els.height = e.clientY - y + 'px'

      }

      //停止事件

      function mouseUp() {

        //在支持 releaseCapture 做些东东

        el.releaseCapture ? (

          //释放焦点

          el.releaseCapture(),

          //移除事件

          el.onmousemove = el.onmouseup = null

        ) : (

            //卸载事件

            $(document).unbind("mousemove", mouseMove).unbind("mouseup", mouseUp)

          )

      }

    }

  </script>

</head>

 

<body>

  <div id="resizeable" class="ui-widget-content" style="border: 1px solid red; width: 400px; height: 300px;">

    <h3 class="ui-widget-header">Resizable</h3>

  </div>

</body>

 

</html>

要实现同时兼容 PC 端和移动端的元素拖拽功能,可以使用 HTML5 新增的 drag 事件和 touch 事件。 首先,需要将元素设置为可拖拽,可以使用 draggable 属性。例如: ```html <div draggable="true">可拖拽的元素</div> ``` 然后,需要监听元素的 dragstart、drag、dragend 事件或 touchstart、touchmove、touchend 事件来实现拖拽效果。 在 PC 端,可以使用 drag 事件来实现拖拽效果,例如: ```javascript var dragElement = document.getElementById('drag-element'); dragElement.addEventListener('dragstart', function(event) { // 拖拽开始时,保存拖拽元素的 ID event.dataTransfer.setData('text/plain', event.target.id); }); document.body.addEventListener('dragover', function(event) { // 阻止默认拖拽行为 event.preventDefault(); }); document.body.addEventListener('drop', function(event) { // 阻止默认拖拽行为 event.preventDefault(); // 获取拖拽元素的 ID var id = event.dataTransfer.getData('text/plain'); var dragElement = document.getElementById(id); // 将拖拽元素添加到放置区域 event.target.appendChild(dragElement); }); ``` 在移动端,可以使用 touch 事件来实现拖拽效果,例如: ```javascript var dragElement = document.getElementById('drag-element'); var startX, startY; dragElement.addEventListener('touchstart', function(event) { startX = event.touches[0].clientX; startY = event.touches[0].clientY; }); dragElement.addEventListener('touchmove', function(event) { var offsetX = event.touches[0].clientX - startX; var offsetY = event.touches[0].clientY - startY; // 移动元素 this.style.transform = 'translate(' + offsetX + 'px, ' + offsetY + 'px)'; }); dragElement.addEventListener('touchend', function(event) { // 拖拽结束时,清除 transform 样式 this.style.transform = ''; }); ``` 需要注意的是,移动端的 touch 事件可能会和浏览器默认行为冲突,需要使用 preventDefault() 方法来阻止默认行为。另外,由于移动端的屏幕尺寸多样化,需要根据具体情况来调整拖拽的逻辑和样式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值