選單
×
   ❮     
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE
     ❯   

HOW TO

HowTo Home

Menus

圖示欄 選單圖示 手風琴 標籤頁 垂直標籤頁 標籤頁標題 全屏標籤頁 懸停標籤頁 頂部導航 響應式頂部導航 分割導航 帶圖示的導航欄 搜尋選單 搜尋欄 固定側邊欄 側邊導航 響應式側邊欄 全屏導航 畫外畫選單 懸停側邊欄按鈕 帶圖示的側邊欄 水平滾動選單 垂直選單 底部導航 響應式底部導航 底部邊框導航連結 右對齊菜單鏈接 居中菜單鏈接 等寬菜單鏈接 固定選單 滾動時下拉導航欄 滾動時隱藏導航欄 滾動時收縮導航欄 粘性導航欄 圖片上的導航欄 懸停下拉選單 點選下拉選單 級聯下拉選單 頂欄中的下拉選單 側邊欄中的下拉選單 響應式導航欄下拉選單 子導航選單 向上拉起選單 巨型選單 移動選單 窗簾選單 摺疊側邊欄 摺疊側面板 分頁 麵包屑導航 按鈕組 垂直按鈕組 粘性社交欄 藥丸導航 響應式頁首

圖片

幻燈片 幻燈片畫廊 模態框影像 燈箱 響應式影像網格 影像網格 影像畫廊 可滾動影像畫廊 標籤頁畫廊 影像覆蓋淡入 影像覆蓋滑動 影像覆蓋縮放 影像覆蓋標題 影像覆蓋圖示 影像效果 黑白影像 影像文字 影像文字塊 透明影像文字 全屏影像 圖片上的表單 英雄影像 模糊背景影像 滾動時更改背景 並排影像 圓角影像 頭像影像 響應式影像 居中影像 縮圖 影像周圍的邊框 認識團隊 粘性影像 翻轉影像 搖晃影像 作品集畫廊 帶過濾器的作品集 影像縮放 影像放大鏡 影像比較滑塊 網站圖示

按鈕

警報按鈕 輪廓按鈕 分割按鈕 動畫按鈕 淡入淡出按鈕 圖片上的按鈕 社交媒體按鈕 閱讀更多/閱讀更少 載入按鈕 下載按鈕 藥丸按鈕 通知按鈕 圖示按鈕 下一/上一頁按鈕 導航中的更多按鈕 塊狀按鈕 文字按鈕 圓形按鈕 滾動到頂部按鈕

表單

登入表單 登錄檔單 結賬表單 聯絡表單 社交登入表單 登錄檔單 帶圖示的表單 新聞通訊 堆疊表單 響應式表單 彈出表單 內聯表單 清除輸入欄位 隱藏數字箭頭 複製文字到剪貼簿 動畫搜尋 搜尋按鈕 全屏搜尋 導航欄中的輸入框 導航欄中的登入表單 自定義複選框/單選按鈕 自定義選擇器 切換開關 選中複選框 檢測大寫鎖定 按 Enter 觸發按鈕 密碼驗證 切換密碼可見性 多步表單 自動完成 關閉自動完成 關閉拼寫檢查 檔案上傳按鈕 空輸入驗證

Filters

篩選列表 篩選表格 篩選元素 篩選下拉選單 排序列表 排序表格

表格

斑馬條紋表 居中文件 全寬表 巢狀表 並排表 響應式表 對比表

More

全屏影片 模態框 刪除模態框 時間軸 滾動指示器 進度條 技能條 範圍滑塊 顏色選擇器 電子郵件欄位 工具提示 懸停時顯示元素 彈出視窗 可摺疊 日曆 HTML 包含 待辦事項列表 載入器 徽章 星級評分 使用者評分 疊加效果 聯絡資訊晶片 卡片 翻轉卡片 個人資料卡片 產品卡片 警報 撥出 備註 標籤 絲帶 標籤雲 圓形 樣式 HR 優惠券 列表組 帶徽章的列表組 無專案符號的列表 響應式文字 鏤空文字 發光文字 固定頁尾 粘性元素 等高 清除浮動 響應式浮動 Snackbar 全屏視窗 滾動繪製 平滑滾動 漸變背景滾動 粘性頁首 滾動時收縮頁首 定價表 視差滾動 縱橫比 響應式 iframe 切換喜歡/不喜歡 切換隱藏/顯示 切換暗模式 切換文字 切換類 新增類 移除類 更改類 活動類 樹狀檢視 移除小數 移除屬性 離線檢測 查詢隱藏元素 重定向網頁 格式化數字 懸停縮放 翻轉框 垂直居中 DIV 中居中按鈕 居中列表 懸停過渡 箭頭 形狀 下載連結 全高元素 瀏覽器視窗 自定義捲軸 隱藏捲軸 顯示/強制顯示捲軸 裝置外觀 Contenteditable 邊框 佔位符顏色 停用文字區域的調整大小 停用文字選擇 文字選擇顏色 專案符號顏色 垂直線 分隔符 文字分隔符 動畫圖示 倒計時計時器 打字機 即將推出頁面 聊天訊息 彈出聊天視窗 分屏 客戶評價 章節計數器 名言幻燈片 可關閉的列表項 典型裝置斷點 可拖動的 HTML 元素 JS 媒體查詢 語法高亮 JS 動畫 JS 字串長度 JS 指數運算 JS 預設引數 JS 隨機數 JS 對數字陣列排序 JS 擴充套件運算子 JS 滾動到檢視 獲取當前日期 獲取當前 URL 獲取當前螢幕尺寸 獲取 Iframe 元素

網站

建立免費網站 製作網站 製作靜態網站 託管靜態網站 製作網站 (W3.CSS) 製作網站 (BS3) 製作網站 (BS4) 製作網站 (BS5) 建立和檢視網站 建立 Link Tree 網站 建立作品集 建立簡歷 製作餐廳網站 製作商業網站 製作 WebBook 居中網站 聯絡部分 關於頁面 大標題 示例網站

Grid

2 列布局 3 列布局 4 列布局 展開式網格 列表網格檢視 混合列布局 列卡片 鋸齒佈局 部落格佈局

Google

Google Charts Google Fonts Google Font 配對 Google 設定分析

Converters

轉換重量 轉換溫度 轉換長度 轉換速度

部落格

獲得開發人員工作 成為前端開發人員 聘請開發人員

如何 - 建立可拖動的 HTML 元素


學習如何使用 JavaScript 和 CSS 建立一個可拖動的 HTML 元素。


可拖動的 DIV 元素

點選此處移動

移動

this

DIV










建立可拖動的 DIV 元素

步驟 1) 新增 HTML

示例

<!-- 可拖動的 DIV -->
<div id="mydiv">
  <!-- 包含一個與可拖動 DIV 同名,並在其後附加“header”的標題 DIV -->
  <div id="mydivheader">點選此處移動</div>
  <p>移動</p>
  <p>這個</p>
  <p>DIV</p>
</div>

步驟 2) 新增 CSS

唯一重要的樣式是 position: absolute,其餘部分由您決定

示例

#mydiv {
  position: absolute;
  z-index: 9;
  background-color: #f1f1f1;
  border: 1px solid #d3d3d3;
  text-align: center;
}

#mydivheader {
  padding: 10px;
  cursor: move;
  z-index: 10;
  background-color: #2196F3;
  color: #fff;
}


步驟 3) 新增 JavaScript

示例

// 使 DIV 元素可拖動
dragElement(document.getElementById("mydiv"));

function dragElement(elmnt) {
  var pos1 = 0, pos2 = 0, pos3 = 0, pos4 = 0;
  if (document.getElementById(elmnt.id + "header")) {
    // 如果存在,則標題是移動 DIV 的起點
    document.getElementById(elmnt.id + "header").onmousedown = dragMouseDown;
  } else {
    // 否則,從 DIV 內部的任何位置移動 DIV
    elmnt.onmousedown = dragMouseDown;
  }

  function dragMouseDown(e) {
    e = e || window.event;
    e.preventDefault();
    // 獲取開始時的滑鼠游標位置
    pos3 = e.clientX;
    pos4 = e.clientY;
    document.onmouseup = closeDragElement;
    // 每當游標移動時呼叫一個函式
    document.onmousemove = elementDrag;
  }

  function elementDrag(e) {
    e = e || window.event;
    e.preventDefault();
    // 計算新的游標位置
    pos1 = pos3 - e.clientX;
    pos2 = pos4 - e.clientY;
    pos3 = e.clientX;
    pos4 = e.clientY;
    // 設定元素的​​新位置
    elmnt.style.top = (elmnt.offsetTop - pos2) + "px";
    elmnt.style.left = (elmnt.offsetLeft - pos1) + "px";
  }

  function closeDragElement() {
    // 滑鼠按鈕釋放時停止移動
    document.onmouseup = null;
    document.onmousemove = null;
  }
}
自己動手試一試 »

×

聯絡銷售

如果您想將 W3Schools 服務用於教育機構、團隊或企業,請傳送電子郵件給我們
sales@w3schools.com

報告錯誤

如果您想報告錯誤,或想提出建議,請傳送電子郵件給我們
help@w3schools.com

W3Schools 經過最佳化,旨在方便學習和培訓。示例可能經過簡化,以提高閱讀和學習體驗。教程、參考資料和示例會不斷審查,以避免錯誤,但我們無法保證所有內容的完全正確性。使用 W3Schools 即表示您已閱讀並接受我們的使用條款Cookie 和隱私政策

版權所有 1999-2024 Refsnes Data。保留所有權利。W3Schools 由 W3.CSS 提供支援