js,jQuery实现拖拽自定义移动端板块,web移动端开发

由于项目需求,需要一个能排版移动端页面布局的插件,因此,作为前端的就首当其任了
一般情况下写代码,时间充足我都会先写一遍原生JS 效果,实例代码如下

css :

        <style type="text/css">
            *{
                margin:0;
                padding:0;
            }
            #target{
                width:400px;
                height:700px;
                margin:100px auto;
                border: 1px solid #333;
                position:relative;
            }
            .header{
                height:50px;
                background:blue;
                box-sizing: border-box;
                border: 1px solid #ccc;
                min-width: 320px;
                cursor: all-scroll;
                width: 100%;
            }
            .banner{
                width: 100%;
                height:100px;
                background:aquamarine;
                box-sizing: border-box;
                border: 1px solid #ccc;
                cursor: all-scroll;
            }
            .describe{
                width: 100%;
                height:150px;
                background:pink;
                box-sizing: border-box;
                border: 1px solid #666;
                cursor: all-scroll;
            }
            .details{
                width: 100%;
                height:300px;
                background:green;
                box-sizing: border-box;
                border: 1px solid #666;
                cursor: all-scroll;
            }
        style>

html:

    id="target">
            <div class="header">div>
            <div class="banner">div>       
            <div class="describe">div>
            <div class="details">div>
    
js:
        <script type="text/javascript">
        window.onload = function  () {
            var objP = document.getElementById('target');
            objP.onmousedown = function (ev){
                var oEe = ev || event;
                var oSrc = oEe.srcElement || oEe.target;
                if (oSrc.nodeName == 'DIV'){
                    var oldY = oEe.clientY;
                    var oldX = oEe.clientX;
                    var iTop = oSrc.offsetTop;
                    var iLeft = oSrc.offsetLeft;
                    var iW  = oSrc.offsetWidth;
                    var iH = oSrc.offsetHeight;


                    oSrc.style.position = 'absolute';
                    oSrc.style.top = iTop + 'px';
                    oSrc.style.left = iLeft + 'px';

                    var oSpan = document.createElement('span');
                    oSpan.style.display = 'block';
                    oSpan.style.height = iH + 'px';
                    oSpan.style.width = iW + 'px';
                    oSpan.style.border = '2px dashed #666';
                    oSpan.style.boxSizing = 'border-box';
                    oSpan.id = 'obj1';
                    objP.insertBefore(oSpan,oSrc);

                    //console.debug(oldY,oldX,iTop,iLeft);
                    document.onmousemove = function  (ev) {
                        var oEe = ev || event;
                        var iNowT = oSrc.offsetTop;
                        var iT = oEe.clientY - oldY + iTop;
                        oSrc.style.top = iT + 'px';
                        if (iT - iNowT < 0){
                            var obj = document.getElementById('obj1');
                            var prev = obj.previousElementSibling;
                            if (prev){
                                var prevTop = prev.offsetTop;
                                var prevH = prev.offsetHeight/2;

                                if (iT <= (prevTop + prevH)){

                                    var objNext = obj.nextElementSibling;
                                    objP.removeChild(prev);
                                    objP.insertBefore(prev,objNext);
                                }
                            }


                        }else if (iT - iTop > 0){
                            var obj = document.getElementById('obj1');
                            var next = obj.nextElementSibling;
                            console.debug(next);
                            if (next){
                                var nextTop = next.offsetTop;
                                var nextH = next.offsetHeight/2;
                                if ((iT + iH)>= (nextTop + nextH)){
                                    var obj = document.getElementById('obj1');
                                    objP.removeChild(next);
                                    objP.insertBefore(next,obj);
                                }
                            }

                        }
                        return false;
                        //oSrc.setCapture && oSrc.setCapture();
                    };
                    document.onmouseup = function  () {
                        var change = oSrc.cloneNode(true);
                        //console.debug(change);
                        change.removeAttribute('style');
                        //oSrc.releaseCapture && oSrc.releaseCapture();
                        objP.removeChild(oSrc);
                        var obj = document.getElementById('obj1');
                        objP.insertBefore(change,obj);
                        objP.removeChild(obj);

                        document.onmousemove = document.onmouseup = null;

                    }

                }else{
                    return;
                }
                return false;
            };
        };
    script>
这只是原生js的参考实例

然后后台需求弄成Jquery 插件

<html>
    <head>
        <meta charset="UTF-8">
        <title>drag布局title>
        <script src="js/jquery.min.js" type="text/javascript" charset="utf-8">script>
        <script src="js/dargFlex.js" type="text/javascript" charset="utf-8">script>

        <style type="text/css">
            *{
                margin:0;
                padding:0;
            }
            #target{
                border: 1px solid #666;
                margin:0 auto;
                position:relative;

            }
            .header{
                height:50px;
                background: #FFA500;
                cursor: all-scroll;
            }
            .banner{
                height:100px;
                background: lawngreen;
                cursor: all-scroll;
            }
            .nav{
                height:50px;
                background: hotpink;
                cursor: all-scroll;
            }
            .menu{
                height:200px;
                background: mediumvioletred;
                cursor: all-scroll;
            }
        style>
        <script type="text/javascript">
            $(function  () {
                $(target).dargFlex('drag');
            });
        script>
    head>
    <body id="target">
        <div class="header drag">div>
        <div class="banner drag">div>
        <div class="nav drag">div>
        <div class="menu drag">div>

    body>
html>
(function  ($) {
    $.fn.dargFlex = function  (classN,json) {
        console.debug(typeof this);
        var json = json || {};
        json.dragStyle = json.dragStyle || {};
        json.siteStyle = json.siteStyle || {};
        json.dragStyle.zIndex = json.dragStyle.zIndex  || 2;
        json.dragStyle.opacity = json.dragStyle.opacity || 1;
        json.dragStyle.border = json.dragStyle.border || 'none';
        json.siteStyle.opacity = json.siteStyle.opacity || 1;
        json.siteStyle.border = json.siteStyle.border || '2px dashed #666';
        json.siteStyle.bgColor = json.siteStyle.bgColor || '#FFF';

        var classN = classN || 'dragObj';
        var $this = this;
        this.bind('mousedown',function (ev){
            var oEe = ev || event;
            var oSrc = oEe.srcElement || oEe.target;            //默认不带参数,默认全部子项拖拽
            if ($(oEe.target).hasClass(classN)){       //默认以类名匹配拖拽元素
                var oldY = oEe.clientY;
                var oldX = oEe.clientX;
                var iTop = oEe.target.offsetTop;
                var iLeft = oEe.target.offsetLeft;
                var iW  = oEe.target.offsetWidth;
                var iH = oEe.target.offsetHeight;
                $(oEe.target).css({
                    'position':'absolute',
                    'top':iTop+'px',
                    'left':iLeft + 'px',
                    'width':iW +'px',
                    'z-index':json.dragStyle.zIndex,
                    'opacity':json.dragStyle.opacity,
                    'border':json.dragStyle.border
                });
                var oSpan = document.createElement('span');
                $(oSpan).css({
                    'display':'block',
                    'height':iH + 'px',
                    'width': iW + 'px',
                    'opacity':json.siteStyle.opacity,
                    'border':json.siteStyle.border,
                    'background':json.siteStyle.bgColor,
                    'box-sizing':'border-box',
                    '-webkit-box-sizing':'border-box',
                    '-ms-box-sizing':'border-box',
                    '-moz-box-sizing':'border-box'
                });
                $(oSpan).attr('id','obj');
                //console.debug(this);
                //objP.insertBefore(oSpan,oSrc);
                $this[0].insertBefore(oSpan,oSrc); 
                function move (ev) {
                    var oEe = ev || event;
                    var newY = oEe.clientY;
                    var iNowT = oEe.target.offsetTop;
                    var iT = newY - oldY + iTop;
                    $(oSrc).css('top',iT+'px');

                    if (iT - iNowT < 0){
                        var obj = document.getElementById('obj');
                        var prev = obj.previousElementSibling;
                        if (prev){
                            var pTop = prev.offsetTop;
                            var pH = prev.offsetHeight/2;
                            if (iT <= (pTop + pH)){
                                $this[0].removeChild(prev);
                                var objNext = obj.nextElementSibling;
                                $this[0].insertBefore(prev,objNext);
                            }
                        }
                    }
                    if (iT - iNowT > 0){
                        var obj = document.getElementById('obj');
                        var next = obj.nextElementSibling;
                        if (next){
                            var nTop = next.offsetTop;
                            var nH = next.offsetHeight/2;
                            if ((iT + iH) >= (nTop + nH)){
                                $this[0].removeChild(next);
                                $this[0].insertBefore(next,obj);
                            }
                        }
                    }
                    oEe.preventDefault();
                }
                function dragUp (ev) {
                    var change = ev.target.cloneNode(true);
                    var obj = document.getElementById('obj');
                    //$(ev.target).remove();
                    $this[0].removeChild(oSrc);
                    $(oSrc).removeAttr('style');
                    $('#obj').before(oSrc);

                    $this[0].removeChild(obj);

                    $(document).unbind('mousemove',move);
                    $(document).unbind('mouseup',dragUp);

                }
                $(document).bind('mousemove',move);
                $(document).bind('mouseup',dragUp);
            }

            oEe.preventDefault();
        });
    }
})(jQuery);
/*

 - 
 - API 文档
 - 
 - 
 - jQuery.dargFlex(classN,json)
 - 
 - jQuery = parentNode
 - 
 - 参数:
 - classN = 指定的触发拖拽的唯一源头的类名,必须给
 - 
 - json = 关于拖拽元素和定位元素的样式,携带两个key
 - json.dragStyle = {};     拖拽元素
 - 可以修改
 -  opacity     json.dragStyle.opacity
 -  border      json.dragStyle.border
 -  z-index     json.dragStyle.zIndex
 - 
 - json.siteStyle = {};     定位元素
 - 可修改
 - opacity      json.siteStyle.opacity
 - border       json.siteStyle.border
 - zIndex       json.siteStyle.zIndex
 - 
 - 
 - */
  • 列表内容

你可能感兴趣的:(js,jquery)