91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

js怎么實現響應按鈕點擊彈出可拖拽的非模態對話框

發布時間:2023-04-28 10:29:57 來源:億速云 閱讀:128 作者:iii 欄目:開發技術

今天小編給大家分享一下js怎么實現響應按鈕點擊彈出可拖拽的非模態對話框的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

1.css部分:

.dialog {
  display: none;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background-color: #fff;
  border-radius: 5px;
  box-shadow: 0 10px 20px rgba(0, 0, 0, .3);
  z-index: 9999;
}

.dialog-header {
  background-color: #f6f7f8;
  padding: 10px;
  border-top-left-radius: 5px;
  border-top-right-radius: 5px;
  cursor: move;
}

.dlgtitle {
  font-weight: bold;
  font-size: 16px;
}

.close-btn {
  float: right;
  cursor: pointer;
}

.dialog-content {
  padding: 20px;
}

2.html部分:

<button id="openBtn">打開對話框</button>

<div id="dialog" class="dialog">
  <div class="dialog-header">
    <span class="dlgtitle">對話框標題</span>
    <span class="close-btn">&times;</span>
  </div>
  <div class="dialog-content">
    <p>這里是對話框內容</p>
  </div>
</div>

3.JavaScript部分:

var dialog = document.getElementById('dialog');
var openBtn = document.getElementById('openBtn');
var closeBtn = document.querySelector('.close-btn');
var isDragging = false;
var mouseX, mouseY, dialogLeft, dialogTop;

// 鼠標按下時記錄鼠標位置以及對話框位置
dialogHeaderMouseDown = function(e) {
  isDragging = true;
  mouseX = e.clientX;
  mouseY = e.clientY;
  dialogLeft = dialog.offsetLeft;
  dialogTop = dialog.offsetTop;
}

// 鼠標移動時移動對話框
// document.onmousemove = function(e) {
dialogHeaderMouseMove = function(e) {
  if (isDragging) {
    var moveX = e.clientX - mouseX;
    var moveY = e.clientY - mouseY;
    dialog.style.left = dialogLeft + moveX + 'px';
    dialog.style.top = dialogTop + moveY + 'px';
  }
}

// 鼠標松開時停止拖動
// document.onmouseup = function() {
dialogHeaderMouseup = function() {
  isDragging = false;
}

// 點擊打開按鈕顯示對話框
openBtn.onclick = function() {
  dialog.style.display = 'block';
}

// 點擊關閉按鈕或對話框外部關閉對話框
closeBtn.onclick = function() {
  dialog.style.display = 'none';
}

dialog.onclick = function(e) {
  if (e.target == dialog) {
    dialog.style.display = 'none';
  }
}

// 鼠標按下對話框頭部,開始拖動對話框
var header = document.querySelector('.dialog-header');
header.addEventListener('mousedown', dialogHeaderMouseDown);
header.addEventListener('mousemove', dialogHeaderMouseMove);
header.addEventListener('mouseup', dialogHeaderMouseup);

可以使用本站在線工具:http://tools.jb51.net/code/WebCodeRun 測試上述代碼運行效果。

附:完整示例代碼:

<!DOCTYPE html>
<html lang="zh_CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>可拖拽非模態對話框</title>
<style>
.dialog {
  display: none;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background-color: #fff;
  border-radius: 5px;
  box-shadow: 0 10px 20px rgba(0, 0, 0, .3);
  z-index: 9999;
}

.dialog-header {
  background-color: #f6f7f8;
  padding: 10px;
  border-top-left-radius: 5px;
  border-top-right-radius: 5px;
  cursor: move;
}

.dlgtitle {
  font-weight: bold;
  font-size: 16px;
}

.close-btn {
  float: right;
  cursor: pointer;
}

.dialog-content {
  padding: 20px;
}
</style>
</head>
<body>
<button id="openBtn">打開對話框</button>
<div id="dialog" class="dialog">
  <div class="dialog-header">
    <span class="dlgtitle">對話框標題</span>
    <span class="close-btn">&times;</span>
  </div>
  <div class="dialog-content">
    <p>這里是對話框內容</p>
  </div>
</div>
<script>
var dialog = document.getElementById('dialog');
var openBtn = document.getElementById('openBtn');
var closeBtn = document.querySelector('.close-btn');
var isDragging = false;
var mouseX, mouseY, dialogLeft, dialogTop;

// 鼠標按下時記錄鼠標位置以及對話框位置
dialogHeaderMouseDown = function(e) {
  isDragging = true;
  mouseX = e.clientX;
  mouseY = e.clientY;
  dialogLeft = dialog.offsetLeft;
  dialogTop = dialog.offsetTop;
}

// 鼠標移動時移動對話框
// document.onmousemove = function(e) {
dialogHeaderMouseMove = function(e) {
  if (isDragging) {
    var moveX = e.clientX - mouseX;
    var moveY = e.clientY - mouseY;
    dialog.style.left = dialogLeft + moveX + 'px';
    dialog.style.top = dialogTop + moveY + 'px';
  }
}

// 鼠標松開時停止拖動
// document.onmouseup = function() {
dialogHeaderMouseup = function() {
  isDragging = false;
}

// 點擊打開按鈕顯示對話框
openBtn.onclick = function() {
  dialog.style.display = 'block';
}

// 點擊關閉按鈕或對話框外部關閉對話框
closeBtn.onclick = function() {
  dialog.style.display = 'none';
}

dialog.onclick = function(e) {
  if (e.target == dialog) {
    dialog.style.display = 'none';
  }
}

// 鼠標按下對話框頭部,開始拖動對話框
var header = document.querySelector('.dialog-header');
header.addEventListener('mousedown', dialogHeaderMouseDown);
header.addEventListener('mousemove', dialogHeaderMouseMove);
header.addEventListener('mouseup', dialogHeaderMouseup);
</script>
</body>
</html>

以上就是“js怎么實現響應按鈕點擊彈出可拖拽的非模態對話框”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

js
AI

贺兰县| 平舆县| 刚察县| 万源市| 理塘县| 班玛县| 三原县| 弥渡县| 万宁市| 伊川县| 高安市| 望江县| 英吉沙县| 清镇市| 徐汇区| 元江| 齐河县| 曲阳县| 武穴市| 天津市| 漳州市| 涪陵区| 合阳县| 塘沽区| 德兴市| 平阴县| 南乐县| 邓州市| 射洪县| 香格里拉县| 昭通市| 昌宁县| 邹平县| 乐平市| 通州市| 平定县| 新平| 浠水县| 绍兴市| 天津市| 黄陵县|