一鍵擁有10個城市分站
關鍵詞免費占領百度首頁
關于js拖拽早已是老生常談,網(wǎng)上一搜一大坨,但是有很多并不是很完善,或者兼容性不夠,或者功能不全,并且這樣的東西還是自己寫的好用。我打算在(一)中主要對js拖拽功能的注意點進行羅列,力求簡單;在(二)中利用(一)的拖拽去實現(xiàn)類似google個性化首頁的拖拽模塊功能。 首先貼上完整code(IE/FF/Chrome) |
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" > <head> <title></title> <script type="text/javascript"> var Common = { getEvent: function() {//ie/ff if (document.all) { return window.event; } func = getEvent.caller; while (func != null) { var arg0 = func.arguments[0]; if (arg0) { if ((arg0.constructor == Event || arg0.constructor == MouseEvent) || (typeof (arg0) == "object" && arg0.preventDefault && arg0.stopPropagation)) { return arg0; } } func = func.caller; } return null; }, getMousePos: function(ev) { if (!ev) { ev = this.getEvent(); } if (ev.pageX || ev.pageY) { return { x: ev.pageX, y: ev.pageY }; } if (document.documentElement && document.documentElement.scrollTop) { return { x: ev.clientX + document.documentElement.scrollLeft - document.documentElement.clientLeft, y: ev.clientY + document.documentElement.scrollTop - document.documentElement.clientTop }; } else if (document.body) { return { x: ev.clientX + document.body.scrollLeft - document.body.clientLeft, y: ev.clientY + document.body.scrollTop - document.body.clientTop }; } }, getItself: function(id) { return "string" == typeof id ? document.getElementById(id) : id; }, getViewportSize: { w: (window.innerWidth) ? window.innerWidth : (document.documentElement && document.documentElement.clientWidth) ? document.documentElement.clientWidth : document.body.offsetWidth, h: (window.innerHeight) ? window.innerHeight : (document.documentElement && document.documentElement.clientHeight) ? document.documentElement.clientHeight : document.body.offsetHeight }, isIE: document.all ? true : false, setOuterHtml: function(obj, html) { var Objrange = document.createRange(); obj.innerHTML = html; Objrange.selectNodeContents(obj); var frag = Objrange.extractContents(); obj.parentNode.insertBefore(frag, obj); obj.parentNode.removeChild(obj); } } ///------------------------------------------------------------------------------------------------------ var Class = { create: function() { return function() { this.init.apply(this, arguments); } } } var Drag = Class.create(); Drag.prototype = { init: function(titleBar, dragDiv, Options) { //設置點擊是否透明,默認不透明 titleBar = Common.getItself(titleBar); dragDiv = Common.getItself(dragDiv); this.dragArea = { maxLeft: 0, maxRight: Common.getViewportSize.w - dragDiv.offsetWidth - 2, maxTop: 0, maxBottom: Common.getViewportSize.h - dragDiv.offsetHeight - 2 }; if (Options) { this.opacity = Options.opacity ? (isNaN(parseInt(Options.opacity)) ? 100 : parseInt(Options.opacity)) : 100; this.keepOrigin = Options.keepOrigin ? ((Options.keepOrigin == true || Options.keepOrigin == false) ? Options.keepOrigin : false) : false; if (this.keepOrigin) { this.opacity = 50; } if (Options.area) { if (Options.area.left && !isNaN(parseInt(Options.area.left))) { this.dragArea.maxLeft = Options.area.left }; if (Options.area.right && !isNaN(parseInt(Options.area.right))) { this.dragArea.maxRight = Options.area.right }; if (Options.area.top && !isNaN(parseInt(Options.area.top))) { this.dragArea.maxTop = Options.area.top }; if (Options.area.bottom && !isNaN(parseInt(Options.area.bottom))) { this.dragArea.maxBottom = Options.area.bottom }; } } else { this.opacity = 100, this.keepOrigin = false; } this.originDragDiv = null; this.tmpX = 0; this.tmpY = 0; this.moveable = false; var dragObj = this; titleBar.onmousedown = function(e) { var ev = e || window.event || Common.getEvent(); //只允許通過鼠標左鍵進行拖拽,IE鼠標左鍵為1 FireFox為0 if (Common.isIE && ev.button == 1 || !Common.isIE && ev.button == 0) { } else { return false; } if (dragObj.keepOrigin) { dragObj.originDragDiv = document.createElement("div"); dragObj.originDragDiv.style.cssText = dragDiv.style.cssText; dragObj.originDragDiv.style.width = dragDiv.offsetWidth; dragObj.originDragDiv.style.height = dragDiv.offsetHeight; dragObj.originDragDiv.innerHTML = dragDiv.innerHTML; dragDiv.parentNode.appendChild(dragObj.originDragDiv); } dragObj.moveable = true; dragDiv.style.zIndex = dragObj.GetZindex() + 1; var downPos = Common.getMousePos(ev); dragObj.tmpX = downPos.x - dragDiv.offsetLeft; dragObj.tmpY = downPos.y - dragDiv.offsetTop; titleBar.style.cursor = "move"; if (Common.isIE) { dragDiv.setCapture(); } else { window.captureEvents(Event.MOUSEMOVE); } dragObj.SetOpacity(dragDiv, dragObj.opacity); //FireFox 去除容器內(nèi)拖拽圖片問題 if (ev.preventDefault) { ev.preventDefault(); ev.stopPropagation(); } document.onmousemove = function(e) { if (dragObj.moveable) { var ev = e || window.event || Common.getEvent(); //IE 去除容器內(nèi)拖拽圖片問題 if (document.all) //IE { ev.returnValue = false; } var movePos = Common.getMousePos(ev); dragDiv.style.left = Math.max(Math.min(movePos.x - dragObj.tmpX, dragObj.dragArea.maxRight), dragObj.dragArea.maxLeft) + "px"; dragDiv.style.top = Math.max(Math.min(movePos.y - dragObj.tmpY, dragObj.dragArea.maxBottom), dragObj.dragArea.maxTop) + "px"; } }; document.onmouseup = function() { if (dragObj.keepOrigin) { if (Common.isIE) { dragObj.originDragDiv.outerHTML = ""; } else { Common.setOuterHtml(dragObj.originDragDiv, ""); } } if (dragObj.moveable) { if (Common.isIE) { dragDiv.releaseCapture(); } else { window.releaseEvents(Event.MOUSEMOVE); } dragObj.SetOpacity(dragDiv, 100); titleBar.style.cursor = "default"; dragObj.moveable = false; dragObj.tmpX = 0; dragObj.tmpY = 0; } }; } }, SetOpacity: function(dragDiv, n) { if (Common.isIE) { dragDiv.filters.alpha.opacity = n; } else { dragDiv.style.opacity = n / 100; } }, GetZindex: function() { var maxZindex = 0; var divs = document.getElementsByTagName("div"); for (z = 0; z < divs.length; z++) { maxZindex = Math.max(maxZindex, divs[z].style.zIndex); } return maxZindex; } } window.onload = function() { new Drag("dragDiv", "dragDiv", { opacity: 100, keepOrigin: true }); //, area: { left: 50, right: 500, top: 100, bottom: 400} } </script> </head> <body> <div id="dragDiv" style="position:absolute; background-color:#FFFFFF;border:solid 1px #849BCA;width:200px;left:10px;top:10px;filter:alpha(opacity=100);opacity:1;"> <table cellpadding="0" cellspacing="0" border="0" style="width:100%;border-collapse:collapse; "> <tr id="titleBar" style="height:22px; text-align:left; background-color:#547BC9;color:White; padding:3px;"> <th align="left" unselectable="on" >Title</th> </tr> <tr style="height:130px;padding:3px;" align="left" valign="top" unselectable="on"> <td><img src="http://m.mrpavah.com/images/v4/logo.gif" alt="pic for drag" /> Content...</td> <!----> </tr> </table> </div> <div style="position:absolute; font-family:Tahoma;border:solid 1px #849BCA; background-color:#AAAAAA;width:200px;height:100px;left:210px;top:210px;filter:alpha(opacity=100);opacity:1; z-index:999">Are you able to cover me?</div> </body> </html> |
對Drag的使用:在window.onload中,必填參數(shù)是titleBar和dragDiv,后者是要拖拽的容器,前者是拖拽容器的可拖拽部位,譬如經(jīng)常遇到的通過標題欄拖動整個DIV,則titleBar即為改標題欄。而{ opacity: 100, keepOrigin: true , area: { left: 50, right: 500, top: 100, bottom: 400}} 是可選參數(shù),用于擴展功能,opacity設置透明度,keepOrigin設置拖拽過程中是否保留原來拖拽容器,area設置拖拽范圍。
|
蘇州五金公司
一鍵擁有10個城市分站
關鍵詞免費占領百度首頁
2593條
收錄量暴增
40個
關鍵詞
秦農(nóng)網(wǎng)
小鎮(zhèn)合作社蛻變?nèi)珖r(nóng)特產(chǎn)品牌
打通了線上線下的生意閉環(huán)
5000+
輕松招納會員
70%
實現(xiàn)業(yè)績增長
可可媽母嬰店
手工作坊升級線上品牌分銷網(wǎng)站
讓消費者主動變成銷售員
10倍
分銷用戶增長
1200萬
總業(yè)績突破
同和牛奶
批發(fā)店打造移動電商新模式
深耕本地化社群+團購
30+萬
2個月銷售額
12億
微信用戶數(shù)
旗下網(wǎng)站:耐思智慧 - 淘域網(wǎng) - 我的400電話 - 中文域名:耐思尼克.cn 耐思尼克.top
耐思智慧 © 版權所有 Copyright © 2000-2025 IISP.COM,Inc. All rights reserved
備案號碼: 粵ICP備09063828號 公安備案號: 粵公網(wǎng)安備 44049002000123號 域名注冊服務機構許可:粵D3.1-20240003 CN域名代理自深圳萬維網(wǎng)
聲明:本網(wǎng)站中所使用到的其他各種版權內(nèi)容,包括但不限于文章、圖片、視頻、音頻、字體等內(nèi)容版權歸原作者所有,如權利所有人發(fā)現(xiàn),請及時告知,以便我們刪除版權內(nèi)容
本站程序界面、源代碼受相關法律保護, 未經(jīng)授權, 嚴禁使用; 耐思智慧 © 為我公司注冊商標, 未經(jīng)授權, 嚴禁使用