欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js實現(xiàn)響應按鈕點擊彈出可拖拽的非模態(tài)對話框完整實例【測試可用】 原創(chuàng)

原創(chuàng)  更新時間:2023年04月23日 18:44:00   原創(chuàng) 投稿:shichen2014  
這篇文章主要介紹了js實現(xiàn)響應按鈕點擊彈出可拖拽的非模態(tài)對話框,結(jié)合完整實例形式分析了原生JavaScript實現(xiàn)的可拖拽非模態(tài)對話框?qū)崿F(xiàn)技巧與使用方法,需要的朋友可以參考下

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>這里是對話框內(nèi)容</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';
}

// 點擊關閉按鈕或?qū)υ捒蛲獠筷P閉對話框
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>可拖拽非模態(tài)對話框</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>這里是對話框內(nèi)容</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';
}

// 點擊關閉按鈕或?qū)υ捒蛲獠筷P閉對話框
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>

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

相關文章

  • JS實現(xiàn)深拷貝的幾種簡單方法示例

    JS實現(xiàn)深拷貝的幾種簡單方法示例

    深拷貝和淺拷貝是在JavaScript中復制對象或數(shù)組時經(jīng)常遇到的概念,下面這篇文章主要給大家介紹了關于JS實現(xiàn)深拷貝的幾種簡單方法,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2023-10-10
  • JavaScript獲得當前網(wǎng)頁來源頁面(即上一頁)的方法

    JavaScript獲得當前網(wǎng)頁來源頁面(即上一頁)的方法

    這篇文章主要介紹了JavaScript獲得當前網(wǎng)頁來源頁面(即上一頁)的方法,涉及javascript中document.referrer方法的使用技巧,需要的朋友可以參考下
    2015-04-04
  • typescript枚舉的具體使用

    typescript枚舉的具體使用

    使用枚舉我們可以定義一些帶名字的常量,本文主要介紹了typescript枚舉的具體使用,具有一定的參考價值,感興趣的可以了解一下
    2023-09-09
  • 在js里怎么實現(xiàn)Xcode里的callFuncN方法(詳解)

    在js里怎么實現(xiàn)Xcode里的callFuncN方法(詳解)

    下面小編就為大家?guī)硪黄趈s里怎么實現(xiàn)Xcode里的callFuncN方法(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-11-11
  • JS獲取子窗口中返回的數(shù)據(jù)實現(xiàn)方法

    JS獲取子窗口中返回的數(shù)據(jù)實現(xiàn)方法

    下面小編就為大家?guī)硪黄狫S獲取子窗口中返回的數(shù)據(jù)實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-05-05
  • js多個物體運動功能實例分析

    js多個物體運動功能實例分析

    這篇文章主要介紹了js多個物體運動功能,結(jié)合實例形式分析了js實現(xiàn)多物體運動功能的原理、實現(xiàn)技巧與相關注意事項,需要的朋友可以參考下
    2016-12-12
  • 深入探尋javascript定時器

    深入探尋javascript定時器

    這篇文章主要介紹了深入探尋javascript定時器,十分的詳盡,十分全面,需要的朋友可以參考下
    2015-01-01
  • HTML+CSS+JavaScript實現(xiàn)下拉菜單效果

    HTML+CSS+JavaScript實現(xiàn)下拉菜單效果

    這篇文章主要為大家詳細介紹了HTML+CSS+JavaScript實現(xiàn)下拉菜單效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • JS中hasOwnProperty方法用法簡介

    JS中hasOwnProperty方法用法簡介

    hasOwnProperty(propertyName)方法 是用來檢測屬性是否為對象的自有屬性,如果是,返回true,否者false; 參數(shù)propertyName指要檢測的屬性名,這篇文章給大家介紹JS中hasOwnProperty方法用法簡介,感興趣的朋友一起看看吧
    2024-01-01
  • 微信小程序 連續(xù)旋轉(zhuǎn)動畫(this.animation.rotate)詳解

    微信小程序 連續(xù)旋轉(zhuǎn)動畫(this.animation.rotate)詳解

    這篇文章主要介紹了微信小程序 連續(xù)旋轉(zhuǎn)動畫(this.animation.rotate)詳解的相關資料,需要的朋友可以參考下
    2017-04-04

最新評論