国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

運用js實現圖層拖拽的功能

2024-05-06 16:51:25
字體:
來源:轉載
供稿:網友

1.需求分析:設計一個元素,可以跟隨鼠標的移動,元素也進行移動,并且能夠在鼠標按上與按下元素的時候,元素同樣可以進行改變樣式顏色。

2. 設計思路:先是需要獲取元素,給元素綁定鼠標按下的事件,在綁定的事件中,兼容event事件,獲取鼠標的坐標和元素的坐標,通過鼠標的坐標減去元素的坐標就可以得到鼠標在元素中的坐標。在綁定事件中,寫上一個元素的移動事件,獲取元素的移動坐標。最后,在鼠標按上的事件函數中,可以調用元素的移動事件就可以了。

<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>圖層拖拽</title> <style> .box { width: 200px; height: 200px; background-color: skyblue; border: 2px solid #ccc; cursor: pointer; position: absolute; top: 20px; left: 100px; } </style></head><body><div class="box" id="box"></div></body><script> var box = document.getElementById("box"); box.onmousedown = function(env){ // 兼容event事件 var env = env || window.event; // 獲取鼠標的坐標 var x = env.clientX; var y = env.clientY; // 獲取元素的坐標 var left = box.offsetLeft; var top = box.offsetTop; // 獲取鼠標在元素中的坐標 var x_left = x - left; var y_top = y -top; // 鼠標點擊后改變顏色 box.style.background = "red"; // 元素的移動事件函數 box.onmousemove = function(env){ // 兼容event事件 var env = env || window.event; // 獲取元素移動時的鼠標的坐標 var x = env.clientX; var y = env.clientY; // 元素的移動坐標 box.style.left = (x - x_left)+"px"; box.style.top = (y - y_top)+"px"; } }; // 鼠標彈出的事件函數 box.onmouseup = function(){ box.style.background = "skyblue"; // 在鼠標彈出后再次調用元素的鼠標移動事件 box.onmousemove = function(){}; };</script></html>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 无棣县| 安义县| 樟树市| 孝感市| 常德市| 苗栗市| 定襄县| 宁夏| 张家界市| 云和县| 清涧县| 鹤壁市| 西贡区| 观塘区| 万州区| 滕州市| 阳朔县| 南皮县| 合作市| 孝昌县| 策勒县| 抚宁县| 麻栗坡县| 蒙城县| 伊金霍洛旗| 马龙县| 丹巴县| 襄垣县| 无棣县| 萍乡市| 灵宝市| 桐乡市| 漳平市| 南陵县| 屏东市| 遵义市| 乌海市| 枣庄市| 江津市| 九寨沟县| 广宗县|