JQuery+drag.js上傳圖片并且實(shí)現(xiàn)圖片拖曳
外層的容器的id屬性應(yīng)為'container'
容器中有多個(gè)隊(duì)列,這些隊(duì)列之間可以隨意拖動(dòng),class屬性應(yīng)為'queue'
隊(duì)列中有多個(gè)拖動(dòng)塊,class屬性應(yīng)為'dragger'
把拖動(dòng)塊拖到隊(duì)列的尾部空白處會(huì)使這個(gè)拖動(dòng)塊加到隊(duì)列尾部
1.html部分:
<tr> <td><span class="colorred">* </span>商品展示圖片:</td> <td style="padding:20px 20px 20px 0"> <div id="container11" style="padding:20px 0; border: 1px #ededed solid;"> <ul class="shop_imgs queue" style="width: 746px; height: 100px;"> <li class="dragger" data-id="1"> <input type="file" name="files[]" class="qy_yyzz1 f" onchange="handleFiles(this.files,this.parentNode)"> </li> <li class="dragger" data-id="2"> <input type="file" name="files[]" class="qy_yyzz2 f" onchange="handleFiles(this.files,this.parentNode)"> </li> <li class="dragger" data-id="3"> <input type="file" name="files[]" class="qy_yyzz3 f" onchange="handleFiles(this.files,this.parentNode)"> </li> <li class="dragger" data-id="4"> <input type="file" name="files[]" class="qy_yyzz4 f" onchange="handleFiles(this.files,this.parentNode)"> </li> <li class="dragger" data-id="5"> <input type="file" name="files[]" class="qy_yyzz5 f" onchange="handleFiles(this.files,this.parentNode)"> </li> </ul> </div> </td> </tr>
js部分:
<script type="text/javascript" src="jquery-1.9.1.min.js"></script> <script type="text/javascript" src="/drag/drag.js"></script> <script type="text/javascript" src="/drag/main.js"></script> //構(gòu)建預(yù)覽上傳圖片的函數(shù),并接收傳遞過(guò)來(lái)的2個(gè)變量參數(shù) function handleFiles(file, obj) { var val=file[0].name if (!/.(gif|jpg|jpeg|png|GIF|JPG|bmp)$/.test(val)) { layer.msg('圖片類型必須是.gif,jpeg,jpg,png,bmp中的一種', {icon: 0,time: 2000, title: '提示'}); return false; } //獲取當(dāng)前點(diǎn)擊的元素的所有同級(jí)元素的html內(nèi)容 var con = obj.innerHTML; //判斷當(dāng)前點(diǎn)擊元素內(nèi)是否已經(jīng)存在img圖片元素,如果有則先全部清除后再添加,如果沒(méi)有就直接添加 if (con.indexOf("img") > 0) { var pic = obj.getElementsByTagName("img"); for (var i = 0; i < pic.length; i++) { obj.removeChild(pic[i]); } //調(diào)用添加img圖片的函數(shù) creatImg(); } else { creatImg(); } function creatImg() { //創(chuàng)建一個(gè)img元素 var img = document.createElement("img"); // 創(chuàng)建一個(gè)刪除img var del =document.createElement("span") //設(shè)置img元素的源文件路徑,window.URL.createObjectURL() 方法會(huì)根據(jù)傳入的參數(shù)創(chuàng)建一個(gè)指向該參數(shù)對(duì)象的URL. 這個(gè)URL的生命僅存在于它被創(chuàng)建的這個(gè)文檔里 img.src = window.URL.createObjectURL(file[0]); //window.URL.revokeObjectURL() 釋放一個(gè)通過(guò)URL.createObjectURL()創(chuàng)建的對(duì)象URL,在圖片被顯示出來(lái)后,我們就不再需要再次使用這個(gè)URL了,因此必須要在加載后釋放它 img.onload = function () { window.URL.revokeObjectURL(this.src); } //在當(dāng)前點(diǎn)擊的input元素后添加剛剛創(chuàng)建的img圖片元素 obj.appendChild(img); obj.appendChild(del); } // 刪除圖片 $(".shop_imgs li span").bind("click",function(){ $(this).siblings("input[type='file']").val('') $(this).siblings('img').remove() $(this).remove() }); } // 圖片禁止拖拽 $('.shop_imgs li').on('mousedown',function (e) { e.preventDefault()
css部分:
.div1-table tr { width: 100%; height: 68px; line-height: 68px; border-bottom: 1px solid #eaeaea; } .div1-table tr td:first-child { padding-left: 30px; width: 16%; } .shop_imgs { display: flex; justify-content: space-around; margin: 20px 0; } .shop_imgs li { position: relative; width: 100px; height: 100px; background: url(../../images/user/shell/plus_sp_img.jpg) no-repeat center; text-align: center; cursor: move; list-style: none; } .shop_imgs input[type="file"] { position: absolute; left: 0; bottom: 0; /* z-index: 3; */ display: inline-block; width: 100%; height: 100%; cursor: pointer; border: none; opacity: 0; padding-left: 10px; } .shop_imgs li span { position: absolute; right: 6px; top: 7px; width: 23px; height: 23px; background: url(../../images/close.png) no-repeat center; background-size: 100%; cursor: pointer; } .shop_imgs li img { position: absolute; top: 10px; left: 10px; width: 80px; height: 80px; }
main.js:
// main.js里面的內(nèi)容是調(diào)用:
(function(){registerDrag($('#container11'));})();
drag.js:
var queueArr = []; var draggers = []; var isDragging = false; var isMouseDown = false; var dragger = null; var mouseX; var mouseY; var draggerLeft; var draggerTop; var clone = null; var DRAG_THRESHOLD = 5; var queueContainer; var queueActive = { }; var queueUnActive = { }; var registerDrag = function (container) { queueContainer = container; $.each(container.find('.queue'), function (index, value) { queueArr[index] = $(value); draggers[index] = []; elements = $(value).find('.dragger'); $.each(elements, function (_index, _value) { draggers[index][_index] = $(_value); }); }); for (var i = 0; i < draggers.length; i++) for (var j = 0; j < draggers[i].length; j++) { draggers[i][j].on('mousedown', dragStart); } $(document).on('mousemove', dragMove); $(document).on('mouseup', dragEnd); } var dragStart = function (e) { e.stopPropagation(); isMouseDown = true; mouseX = e.clientX; mouseY = e.clientY; dragger = $(this); } var dragMove = function (e) { e.stopPropagation(); if (!isMouseDown) return; var dx = e.clientX - mouseX; var dy = e.clientY - mouseY; if (isDragging) { clone.css({ left: draggerLeft + dx, top: draggerTop + dy }); arrangeDragger(); } else if (Math.abs(dx) > DRAG_THRESHOLD || Math.abs(dy) > DRAG_THRESHOLD) { clone = makeClone(dragger); draggerLeft = dragger.offset().left - parseInt(dragger.css('margin-left')) - parseInt(dragger.css('padding-left')); draggerTop = dragger.offset().top - parseInt(dragger.css('margin-top')) - parseInt(dragger.css('padding-top')); clone.css({ left: draggerLeft, top: draggerTop }); queueContainer.append(clone); dragger.css('visibility', 'hidden'); isDragging = true; } } var dragEnd = function (e) { e.stopPropagation(); if (isDragging) { isDragging = false; clone.remove(); dragger.css('visibility', 'visible'); } for (var i = 0; i < queueArr.length; i++) queueArr[i].css(queueUnActive); isMouseDown = false; } // 復(fù)制出來(lái)移動(dòng)的圖片的樣式 var makeClone = function (source) { var res = source.clone(); res.addClass('cloneimg');res.children('img').attr('src','/static/index/images/user/shell/tuozhuai.png');res.css({ position: 'absolute', 'z-index': 100000 }); return res; } var arrangeDragger = function () { for (var i = 0; i < queueArr.length; i++) queueArr[i].css(queueUnActive); var queueIn = findQueue(); if (queueIn != -1) queueArr[queueIn].css(queueActive); var hover = findHover(queueIn); if (hover == null) return; var _hover = hover.hover; var _insert = hover.insert; var queueIdOriginal, drggerIdOriginal; var queueIdHover, drggerIdHover; for (var i = 0; i < draggers.length; i++) for (var j = 0; j < draggers[i].length; j++) { if (draggers[i][j][0] == dragger[0]) { queueIdOriginal = i; drggerIdOriginal = j; } } draggers[queueIdOriginal].splice(drggerIdOriginal, 1); if (_hover) { for (var i = 0; i < draggers.length; i++) for (var j = 0; j < draggers[i].length; j++) { if (_hover && draggers[i][j][0] == _hover[0]) { queueIdHover = i; drggerIdHover = j; } } if (_insert == 'left') { _hover.before(dragger); draggers[queueIdHover].splice(drggerIdHover, 0, dragger); } else { _hover.after(dragger); draggers[queueIdHover].splice(drggerIdHover + 1, 0, dragger); } } else { draggers[queueIn].push(dragger); queueArr[queueIn].append(dragger); } // console.log('******************'); for (var i = 0; i < draggers.length; i++) // for (var j = 0; j < draggers[i].length; j++) // console.log(draggers[i][j][0]); console.log('******************'); } var findQueue = function () { var mx = -1, pos = -1; var cloneTop = clone.offset().top; var cloneHeight = clone.height(); for (var i = 0; i < queueArr.length; i++) { var queueTop = queueArr[i].offset().top; var queueHeight = queueArr[i].height(); var val = Math.min(queueTop + queueHeight, cloneTop + cloneHeight) - Math.max(queueTop, cloneTop); if (val > mx) { mx = val; pos = i; } } return pos; } var findHover = function (queueIn) { if (queueIn == -1) return null; var mx = -1, pos = null; var cloneTop = clone.offset().top; var cloneHeight = clone.height(); var cloneLeft = clone.offset().left; var cloneWidth = clone.width(); var isOwn = false; for (var i = 0; i < draggers[queueIn].length; i++) { var _draggerTop = draggers[queueIn][i].offset().top; var _draggerHeight = draggers[queueIn][i].height(); var vertical = Math.min(_draggerTop + _draggerHeight, cloneTop + cloneHeight) - Math.max(_draggerTop, cloneTop); var _draggerLeft = draggers[queueIn][i].offset().left; var _draggerWidth = draggers[queueIn][i].width(); var horizontal = Math.min(_draggerLeft + _draggerWidth, cloneLeft + cloneWidth) - Math.max(_draggerLeft, cloneLeft); if (vertical <= 0 || horizontal <= 0) continue; var s = vertical * horizontal; if (s <= cloneHeight * cloneWidth / 3) continue; if (draggers[queueIn][i][0] == dragger[0]) { isOwn = true; continue; } if (s > mx) { mx = s; pos = draggers[queueIn][i]; } } if (mx < 0) { if (isOwn) return null; if (draggers[queueIn].length == 0) { return { 'hover': null }; } else { var last, index = draggers[queueIn].length - 1; while (index >= 0 && draggers[queueIn][index][0] == dragger[0]) index--; if (index >= 0) last = draggers[queueIn][index]; else return { 'hover': null }; if (cloneLeft >= last.offset().left + last.width()) return { 'hover': last, 'insert': 'right' }; else return null; } } else { var posMid = (2 * pos.offset().left + pos.width()) / 2; var cloneMid = (2 * clone.offset().left + clone.width()) / 2; if (posMid > cloneMid) return { 'hover': pos, 'insert': 'left' }; else return { 'hover': pos, 'insert': 'right' }; } }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 基于AngularJS拖拽插件ngDraggable.js實(shí)現(xiàn)拖拽排序功能
- 深究AngularJS中ng-drag、ng-drop的用法
- jquery插件jquery.dragscale.js實(shí)現(xiàn)拖拽改變?cè)卮笮〉姆椒?附demo源碼下載)
- js實(shí)現(xiàn)iGoogleDivDrag模塊拖動(dòng)層拖動(dòng)特效的方法
- 一起來(lái)寫段JS drag拖動(dòng)代碼
- 一個(gè)js拖拽的效果類和dom-drag.js淺析
- javascript dragable的Move對(duì)象
- 學(xué)習(xí)drag and drop js實(shí)現(xiàn)代碼經(jīng)典之作
相關(guān)文章
jquery 設(shè)置style:display的方法
這篇文章主要介紹了jquery 設(shè)置style:display的方法,需要的朋友可以參考下2015-01-01jQuery.Highcharts.js繪制柱狀圖餅狀圖曲線圖
這篇文章主要介紹了jQuery.Highcharts.js繪制柱狀圖餅狀圖曲線圖的方法,非常的實(shí)用,小伙伴們可以直接拿到項(xiàng)目中使用。2015-03-03jQuery 中使用JSON的實(shí)現(xiàn)代碼
json 是 Ajax 中使用頻率最高的數(shù)據(jù)格式,在瀏覽器和服務(wù)器中之間的通訊可離不開(kāi)它2011-12-12jQuery中使用了document和window哪些屬性和方法小結(jié)
未列出常見(jiàn)的比如document.getElementById(),object.addEventListener()等。2011-09-09用jQuery中的ajax分頁(yè)實(shí)現(xiàn)代碼
去年的時(shí)候剛接觸Jquery,也就做界面特效用了下,對(duì)其很有興趣,迫于現(xiàn)在項(xiàng)目中不怎么用,對(duì)其甚是想念呀,這不沒(méi)抽點(diǎn)時(shí)間再來(lái)看看Juery中好玩的東西。2011-09-09jquery查找父元素、子元素(個(gè)人經(jīng)驗(yàn)總結(jié))
對(duì)使用js或者jquery查找父元素、子元素比較混淆的朋友可以參考下本文,因?yàn)槭莻€(gè)人總結(jié),用起來(lái)會(huì)比較方便2014-04-04jQuery Selectors(選擇器)的使用(九、表單對(duì)象屬性篇)
本系列文章主要講述jQuery框架的選擇器(Selectors)使用方法,我將以實(shí)例方式進(jìn)行講述,以簡(jiǎn)單,全面為基礎(chǔ),不會(huì)涉及很深,我的學(xué)習(xí)方法:先入門,后進(jìn)階!2009-12-12