验证码: 看不清楚,换一张 查询 注册会员,免验证
  • {{ basic.site_slogan }}
  • 打开微信扫一扫,
    您还可以在这里找到我们哟

    关注我们

jQuery怎么实现点击按钮弹出可拖拽模态对话框

阅读:330 来源:乙速云 作者:代码code

jQuery怎么实现点击按钮弹出可拖拽模态对话框

css部分:

.dialog {
  display: none; /* 初始隐藏 */
  position: absolute;
  width: 300px;
  height: 200px;
  top: 50px;
  left: 50px;
  background-color: #fff;
  border: 1px solid #ccc;
  box-shadow: 0 0 10px rgba(0,0,0,.2);
}
.dialog-header {
  height: 30px;
  line-height: 30px;
  padding: 0 10px;
  font-size: 16px;
  font-weight: bold;
  background-color: #f5f5f5;
  border-bottom: 1px solid #ccc;
  cursor: move; /* 允许拖拽 */
}
.dialog-body {
  padding: 10px;
}

/* 遮罩层样式 */
.mask {
  display: none; /* 初始隐藏 */
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background-color: rgba(0,0,0,.3);
}

html部分:



点击弹出对话框





  对话框
  这里是对话框内容

js部分:

$(function() {
  var $dialog = $('.dialog'); // 对话框
  var $mask = $('.mask'); // 遮罩层
  var isDragging = false; // 是否拖拽中

  // 点击弹出对话框
  $('.dialog-trigger').click(function() {
    $dialog.show(); // 显示对话框
    $mask.show(); // 显示遮罩层
  });

  // 拖拽对话框
  $dialog.find('.dialog-header').mousedown(function(e) {
    isDragging = true; // 开始拖拽
    var startX = e.pageX; // 鼠标按下时的X坐标
    var startY = e.pageY; // 鼠标按下时的Y坐标
    var left = $dialog.offset().left; // 对话框初始的left值
    var top = $dialog.offset().top; // 对话框初始的top值

    // 拖拽事件
    $(document).mousemove(function(e) {
      if (isDragging) {
        var moveX = e.pageX - startX; // 鼠标移动的X距离
        var moveY = e.pageY - startY; // 鼠标移动的Y距离
        $dialog.css({
          left: left + moveX + 'px',
          top: top + moveY + 'px'
        });
      }
    });

    // 停止拖拽事件
    $(document).mouseup(function() {
      isDragging = false;
    });
  });

  // 点击遮罩层或对话框的关闭按钮,隐藏对话框和遮罩层
  $mask.click(function() {
    $dialog.hide();
    $mask.hide();
  });
  $dialog.find('.dialog-close').click(function() {
    $dialog.hide();
    $mask.hide();
  });
});

完整实例如下:





jQuery点击弹出模态对话框








点击弹出对话框





  对话框

  这里是对话框内容









分享到:
*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: hlamps#outlook.com (#换成@)。
相关文章
{{ v.title }}
{{ v.description||(cleanHtml(v.content)).substr(0,100)+'···' }}
你可能感兴趣
推荐阅读 更多>