亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

jquery實現拖拽調整Div大小

2019-11-20 13:16:57
字體:
來源:轉載
供稿:網友

今天寫了一天這個jquery插件:

可以實現對div進行拖拽來調整大小的功能。

復制代碼 代碼如下:

(function ($) {
    $.fn.dragDivResize = function () {
        var deltaX, deltaY, _startX, _startY;
        var resizeW, resizeH;
        var size = 20;
        var minSize = 10;
        var scroll = getScrollOffsets();
        var _this = this;
        for (var i = 0; i < _this.length; i++) {
            var target = this[i];
            $(target).on("mouseover mousemove", overHandler);
        }
        function outHandler() {
            for (var i = 0; i < _this.length; i++) {
                target.style.outline = "none";
            }
            document.body.style.cursor = "default";
        }
        function overHandler(event) {
            target = event.target || event.srcElement;
            var startX = event.clientX + scroll.x;
            var startY = event.clientY + scroll.y;
            var w = $(target).width();
            var h = $(target).height();
            _startX = parseInt(startX);
            _startY = parseInt(startY);
            if ((0 < target.offsetLeft + w - _startX && target.offsetLeft + w - _startX < size) || (0 < target.offsetTop + h - _startY && target.offsetTop + h - _startY < size)) {
                target.style.outline = "2px dashed #333";
                if ((0 > target.offsetLeft + w - _startX || target.offsetLeft + w - _startX > size) && 0 < target.offsetTop + h - _startY && target.offsetTop + h - _startY < size) {
                    resizeW = false;
                    resizeH = true;
                    document.body.style.cursor = "s-resize";
                }
                if (0 < target.offsetLeft + w - _startX && target.offsetLeft + w - _startX < size && (0 > target.offsetTop + h - _startY || target.offsetTop + h - _startY > size)) {
                    resizeW = true;
                    resizeH = false;
                    document.body.style.cursor = "w-resize";
                }
                if (0 < target.offsetLeft + w - _startX && target.offsetLeft + w - _startX < size && 0 < target.offsetTop + h - _startY && target.offsetTop + h - _startY < size) {
                    resizeW = true;
                    resizeH = true;
                    document.body.style.cursor = "se-resize";
                }
                $(target).on('mousedown', downHandler);
            } else {
                resizeW = false;
                resizeH = false;
                $(target).off('mousedown', downHandler);
            }
        }
        function downHandler(event) {
            target = event.target || event.srcElement;
            var startX = event.clientX + scroll.x;
            var startY = event.clientY + scroll.y;
            _startX = parseInt(startX);
            _startY = parseInt(startY);
            if (document.addEventListener) {
                document.addEventListener("mousemove", moveHandler, true);
                document.addEventListener("mouseup", upHandler, true);
            } else if (document.attachEvent) {
                target.setCapture();
                target.attachEvent("onlosecapeture", upHandler);
                target.attachEvent("onmouseup", upHandler);
                target.attachEvent("onmousemove", moveHandler);
            }
            if (event.stopPropagation) {
                event.stopPropagation();
            } else {
                event.cancelBubble = true;
            }
            if (event.preventDefault) {
                event.preventDefault();
            } else {
                event.returnValue = false;
            }
        }
        function moveHandler(e) {
            if (!e) e = window.event;
            var w, h;
            var startX = parseInt(e.clientX + scroll.x);
            var startY = parseInt(e.clientY + scroll.y);
            target = target || e.target || e.srcElement;
            if (target == document.body) {
                return;
            }
            if (resizeW) {
                deltaX = startX - _startX;
                w = $(target).width() + deltaX < minSize ? minSize : $(target).width() + deltaX;
                target.style.width = w + "px";
                _startX = startX;
            }
            if (resizeH) {
                deltaY = startY - _startY;
                h = $(target).height() + deltaY < minSize ? minSize : $(target).height() + deltaY;
                target.style.height = h + "px";
                _startY = startY;
            }
            if (e.stopPropagation) {
                e.stopPropagation();
            } else {
                e.cancelBubble = true;
            }
        }
        function upHandler(e) {
            if (!e) {
                e = window.event;
            }
            resizeW = false;
            resizeH = false;
            target = e.target || e.srcElement;
            $(target).on("mouseout", outHandler);
            if (document.removeEventListener) {
                document.removeEventListener("mousemove", moveHandler, true);
                document.removeEventListener("mouseup", upHandler, true);
            } else if (document.detachEvent) {
                target.detachEvent("onlosecapeture", upHandler);
                target.detachEvent("onmouseup", upHandler);
                target.detachEvent("onmousemove", moveHandler);
                target.releaseCapture();
            }
            if (e.stopPropagation) {
                e.stopPropagation();
            } else {
                e.cancelBubble = true;
            }
        }
        function getScrollOffsets(w) {
            w = w || window;
            if (w.pageXOffset != null) {
                return { x: w.pageXOffset, y: w.pageYOffset };
            }
            var d = w.document;
            if (document.compatMode == "CSS1Compat") {
                return { x: d.documentElement.scrollLeft, y: d.documentElement.scrollTop };
            }
            return { x: d.body.scrollLeft, y: d.body.scrollTop };
        }
    }
}(jQuery));
jQuery("div").dragDivResize();

 記錄一下今天的勞動成果,可能會有很多不成熟的地方,歡迎大家來指正,謝謝!

以上就是本文的全部內容了,希望大家能夠喜歡。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩高清a**址| 91超碰中文字幕久久精品| 深夜福利亚洲导航| 高跟丝袜欧美一区| 中文字幕欧美专区| 亚洲欧美另类人妖| 少妇高潮久久久久久潘金莲| 色老头一区二区三区在线观看| 国产精品久久激情| 一区二区福利视频| 亚洲iv一区二区三区| 久久综合九色九九| 91人成网站www| 国内精品久久久久久久| 精品视频在线播放色网色视频| 欧美性极品xxxx娇小| 欧洲美女免费图片一区| 久久精品国产清自在天天线| 日韩av免费在线播放| 久久久久成人精品| 国产精品中文久久久久久久| 自拍偷拍亚洲一区| 91av在线网站| 成人精品一区二区三区电影免费| 亚洲欧美激情精品一区二区| 欧美日韩久久久久| 国产精品高清在线| 亚洲一区二区三区在线免费观看| 欧美在线激情网| 欧美成人h版在线观看| 亚洲精品国产精品自产a区红杏吧| 色综合久久久888| 国产综合久久久久久| 亚洲精品成人av| 亚洲夜晚福利在线观看| 成人黄色影片在线| 亚洲乱亚洲乱妇无码| 亚洲国产精品高清久久久| 亚洲美女性生活视频| 国产精品久久久999| 久久人人爽人人爽人人片av高请| 欧美精品生活片| 成人免费看片视频| 国产美女搞久久| 国产精品久久久久久久久久东京| 欧美午夜激情小视频| 欧美亚洲国产成人精品| 久色乳综合思思在线视频| 亚洲久久久久久久久久久| 色诱女教师一区二区三区| 欧美电影免费观看| 日韩精品中文字幕有码专区| 国产成人精品最新| 久久精品2019中文字幕| 成人激情黄色网| 国产精品成人一区二区| 亚洲国产精品嫩草影院久久| 欧美多人乱p欧美4p久久| 揄拍成人国产精品视频| 正在播放国产一区| 国产+人+亚洲| 欧美日韩福利在线观看| 美日韩精品免费观看视频| 久久久www成人免费精品| 亚洲石原莉奈一区二区在线观看| 色综合久久久888| 中文字幕综合一区| 久久久精品视频成人| 欧美日韩国产精品一区二区不卡中文| 国产成人精品视频在线| 在线观看免费高清视频97| 欧美性猛交xxxx免费看漫画| 欧美日韩国产黄| 亚洲欧美日韩久久久久久| 欧洲精品在线视频| 亚洲午夜精品久久久久久性色| 欧美成在线视频| 国产精品丝袜久久久久久高清| 一区二区三区国产在线观看| 在线日韩日本国产亚洲| 国产在线不卡精品| 国产在线精品一区免费香蕉| 欧美裸身视频免费观看| 亚洲欧美日韩中文在线| 国产在线观看精品| 日韩成人在线电影网| 国产日韩欧美一二三区| 91精品国产自产在线观看永久| 在线日韩中文字幕| 97视频在线播放| 久久999免费视频| 国产精品成人免费电影| 久久久电影免费观看完整版| 亚洲国产成人久久| 9.1国产丝袜在线观看| 羞羞色国产精品| 26uuu国产精品视频| 国产亚洲精品久久久| 亚洲最新中文字幕| 97人洗澡人人免费公开视频碰碰碰| 欧美激情在线一区| 久久久久成人网| 亚洲自拍偷拍网址| 亚洲国产美女精品久久久久∴| 国产亚洲精品高潮| 91在线免费视频| 国产成人精品最新| 欧美中文在线免费| 久久久精品日本| 日本精品免费一区二区三区| 91精品综合久久久久久五月天| 久久久精品国产亚洲| 国产精品美乳在线观看| 日韩av在线影视| 日韩中文在线中文网三级| 91亚洲va在线va天堂va国| 亚洲精品视频播放| 国产精品欧美亚洲777777| 亚洲人成在线观看网站高清| 亚洲xxxxx| 国产精品视频网站| 国产亚洲精品91在线| 奇米成人av国产一区二区三区| 国产日韩精品电影| 久久久精品一区二区三区| 国产欧美精品在线| 亚洲欧美精品一区| 国产日韩欧美日韩大片| 中文字幕亚洲综合| 精品久久久久久久久久久久| 国产精品久久久久国产a级| 亚洲国产精彩中文乱码av| 久久久久久久久久国产精品| 日本精品va在线观看| 日本不卡高字幕在线2019| 久久久人成影片一区二区三区观看| 韩曰欧美视频免费观看| 97精品在线观看| 国产91免费观看| 亚洲福利精品在线| 精品国产依人香蕉在线精品| 日韩成人av一区| 最好看的2019年中文视频| 亚洲成年网站在线观看| 日本一欧美一欧美一亚洲视频| 国产丝袜视频一区| 性欧美xxxx| 亚洲自拍中文字幕| 精品视频中文字幕| 欧美性受xxxx黑人猛交| 国产精品女人久久久久久| 欧美性生交大片免费| 久久久久久香蕉网| 久久久噜噜噜久久中文字免| 欧美日韩福利电影| 中文字幕欧美国内| 91久久夜色精品国产网站| 日本一区二区在线免费播放| 久久精品国产精品亚洲| 色视频www在线播放国产成人| 亚洲r级在线观看| 欧美日韩国产专区| 91九色在线视频| 亚洲精品日韩欧美|