layui 第三方組件平臺

返回首頁 發(fā)布組件

基于 layui,多圖片上傳后可移動圖片位置,根據(jù)cropper修改的圖片截?。舨茫┥蟼鞑寮?參考@adminxf單圖片)

創(chuàng)建:2019-3-9

文檔

實例:
html
<div class="layui-tab layui-tab-card">
<div class="layui-form" style="padding: 20px 0 0 0;">
<div class="layui-form-item">
<label class="layui-form-label">圖片上傳</label>
<div class="layui-input-inline">
<div class="layui-upload-list layui-icon" id="addZmImg">

</div>
</div>
</div>
<div class="">
<ul id="imgZmList"></ul>
</div>
</div>
</div>
<div id="cropperdiv"></div>
js:
<script>
layui.config({
base: "../../static/js/"
})
layui.use(['form', 'upload'], function () {
var form = layui.form
, $ = layui.jquery
, upload = layui.upload;

//證明多圖片上傳
upload.render({
elem: '#addZmImg'
, url: '上傳路徑'
, multiple: true
, before: function (obj) {
//預讀本地文件示例,不支持ie8
obj.preview(function (index, file, result) {
$('#imgZmList').append('<li style="position:relative"><img name="imgZmList" src="' + result + '"width="150" height="113"><div class="title_cover" name="imgZmName" onclick="divClick(this)"></div><div class="img_edit layui-icon" onclick="croppers_pic(this)"></div><div class="img_close" onclick="deleteElement(this)">X</div></li>');
form.render();
imgMove("imgZmList");
});
}
, done: function (res) {
//上傳完畢
}
});
});
function croppers_pic(obj) {
var src = obj.parentNode.childNodes["0"].src;
layui.use(["croppers"], function () {
var croppers = layui.croppers;
croppers.render({
area: ['900px', '600px'] //彈窗寬度
, imgUrl: src
, url: "/user/upload.asp" //圖片上傳接口返回和(layui 的upload 模塊)返回的JOSN一樣
, done: function (url) { //上傳完畢回調
//更改圖片src
obj.parentNode.childNodes["0"].src = url;
}
});
});
}
</script>
publishImg.js
//圖片移動
function imgMove(obj) {
var oUl = document.getElementById(obj);
var aLi = oUl.getElementsByTagName("li");
var disX = 0;
var disY = 0;
var minZindex = 1;
var aPos = [];
var leftbz = 0;
var topbz = 0;
for (var i = 0; i < aLi.length; i++) {
if (leftbz == 5) {
leftbz = 1;
topbz += 1;
var fdiv = (topbz + 1) * 140;
oUl.style.height = fdiv + 'px';
}
else {
leftbz += 1;
}
//var l = aLi[i].offsetLeft;
//var t = aLi[i].offsetTop;
//此處注意,我是按照控件算出來的。尷尬。。。/(ㄒoㄒ)/~~
var l = 170 * (leftbz - 1) + 10;
var t = 130 * topbz;

aLi[i].style.top = t + "px";
aLi[i].style.left = l + "px";
aPos[i] = { left: l, top: t };
aLi[i].index = i;


}
for (var i = 0; i < aLi.length; i++) {
aLi[i].style.position = "absolute";
aLi[i].style.margin = 0;
setDrag(aLi[i]);
}
//拖拽
function setDrag(obj) {
obj.onmouseover = function () {
obj.style.cursor = "move";
}
obj.onmousedown = function (event) {
var scrollTop = document.documentElement.scrollTop || document.body.scrollTop;
var scrollLeft = document.documentElement.scrollLeft || document.body.scrollLeft;
obj.style.zIndex = minZindex++;
//當鼠標按下時計算鼠標與拖拽對象的距離
disX = event.clientX + scrollLeft - obj.offsetLeft;
disY = event.clientY + scrollTop - obj.offsetTop;
document.onmousemove = function (event) {
//當鼠標拖動時計算div的位置
var l = event.clientX - disX + scrollLeft;
var t = event.clientY - disY + scrollTop;
obj.style.left = l + "px";
obj.style.top = t + "px";
/*for(var i=0;i<aLi.length;i++){
aLi[i].className = "";
if(obj==aLi[i])continue;//如果是自己則跳過自己不加紅色虛線
if(colTest(obj,aLi[i])){
aLi[i].className = "active";
}
}*/
for (var i = 0; i < aLi.length; i++) {
aLi[i].className = "";
}
var oNear = findMin(obj);
if (oNear) {
oNear.className = "active";
}
}
document.onmouseup = function () {
document.onmousemove = null;//當鼠標彈起時移出移動事件
document.onmouseup = null;//移出up事件,清空內存
//檢測是否普碰上,在交換位置
var oNear = findMin(obj);
if (oNear) {
oNear.className = "";
oNear.style.zIndex = minZindex++;
obj.style.zIndex = minZindex++;
startMove(oNear, aPos[obj.index]);
startMove(obj, aPos[oNear.index]);
//交換index
oNear.index += obj.index;
obj.index = oNear.index - obj.index;
oNear.index = oNear.index - obj.index;
} else {

startMove(obj, aPos[obj.index]);
}
}
clearInterval(obj.timer);
return false;//低版本出現(xiàn)禁止符號
}
}
//碰撞檢測
function colTest(obj1, obj2) {
var t1 = obj1.offsetTop;
var r1 = obj1.offsetWidth + obj1.offsetLeft;
var b1 = obj1.offsetHeight + obj1.offsetTop;
var l1 = obj1.offsetLeft;

var t2 = obj2.offsetTop;
var r2 = obj2.offsetWidth + obj2.offsetLeft;
var b2 = obj2.offsetHeight + obj2.offsetTop;
var l2 = obj2.offsetLeft;

if (t1 > b2 || r1 < l2 || b1 < t2 || l1 > r2) {
return false;
} else {
return true;
}
}
//勾股定理求距離
function getDis(obj1, obj2) {
var a = obj1.offsetLeft - obj2.offsetLeft;
var b = obj1.offsetTop - obj2.offsetTop;
return Math.sqrt(Math.pow(a, 2) + Math.pow(b, 2));
}
//找到距離最近的
function findMin(obj) {
var minDis = 999999999;
var minIndex = -1;
for (var i = 0; i < aLi.length; i++) {
if (obj == aLi[i]) continue;
if (colTest(obj, aLi[i])) {
var dis = getDis(obj, aLi[i]);
if (dis < minDis) {
minDis = dis;
minIndex = i;
}
}
}
if (minIndex == -1) {
return null;
} else {
return aLi[minIndex];
}
}
}
//圖片刪除
function deleteElement(Obj) {
Obj.parentNode.parentNode.removeChild(Obj.parentNode);
}
//描述
function divClick(obj) {
layer.prompt({ title: '請?zhí)钚碌拿枋?,并確認', formType: 2 }, function (text, index) {
obj.innerHTML = text;
layer.close(index);
});
}

//圖片裁剪
layui.config({
base: "../../static/js/"
}).extend({
"croppers": "croppers"
});
function croppers_pic(obj) {
var src = obj.parentNode.childNodes["0"].src;
layui.use(["croppers"], function () {
var croppers = layui.croppers;
croppers.render({
area: ['900px', '600px'] //彈窗寬度
, imgUrl: src
, url: "/user/upload.asp" //圖片上傳接口返回和(layui 的upload 模塊)返回的JOSN一樣
, done: function (url) { //上傳完畢回調
//更改圖片src
obj.parentNode.childNodes["0"].src = url;
}
});
});
}
展示:


下載

立即下載
該擴展組件由第三方用戶主動投遞,并由其自身進行維護,本站僅做收集。