zoukankan      html  css  js  c++  java
  • jquery-ui sortable 排序

     

    https://blog.csdn.net/u013066244/article/details/51954198

    <link ref="stylesheet" href="jquery-ui.min.css"/>
    <script type="text/javascript" src="jquery.min.js"></script>
    <script type="text/javascript" src="jquery-ui.min.js"></script>

    <div class="form-group">
      <label class="control-label col-sm-1">曲谱图片</label>
      <ul id="layer-img" class="control-label col-sm-9 sortable" style="text-align: left;">
        <volist name="data.image" id="image">
          <li class="portlet" style="display: inline-block" id="{$image['id']}">
            <img id="sheet_img{$image['id']}" src="{$image['url']}" alt="">
          </li>
        </volist>
      </ul>
    </div>

    <script>
        $('.sortable').sortable({
    items: "li", //只是li可以拖动
    opacity: 0.6, //拖动时,透明度为0.6
    cursor: "move", // 拖拽时的鼠标形状
         forceHelperSize: true, // 自适应placeholder的大小

    //appendTo: '.drag-task', // 拖拽的父级节点(该节点一定要注意,配置错误会导致当前屏幕外的元素没法自动滚动拖拽,两列之间拖拽的滚动也会出问题)
    placeholder:
    "portel-placeholder" //设定占位符,事先设定占位符的样式,拖曳时会出现占位符
    // 拖拽时的倾斜度
    rotate: '5deg',
    // 延迟时间(毫秒),避免和click同时操作时出现的冲突
    delay: 150,
    // 以clone方式拖拽
    helper: 'clone',
    // 拖拽到边框出现滚动的间距,
    scrollSensitivity:scrollingSensitivity,
    // 应用于拖拽空白区域的样式
    placeholder: 'portlet-placeholder ui-state-highlight',
    // 允许拖拽预留空白区域
         forcePlaceholderSize: true,
         // 多个列表之间的拖拽的dom元素
    //connectWith: '.task-lists',

    update: function() { //因为是要拖曳改变图片顺序,所以选择update,拖曳更新后调用函数 var image_ids = $('.sortable').sortable('toArray', {attribute: id});//获取class为sortable的子级的id属性值,并转化为数组; $.ajax({ type: "post", url: "", data: {image_ids}, dataType: "json", success: function(result) { window.location.reload(); //后台获取到数据刷新页面 } }); } }); </script>
    stop: (e, ui) => {
              // 当前拽入的元素
              let item = $(ui.item)
              // 当前拽入元素的下标
              let index = item.index()
              let kid = ''
              // xxxx 这里面可以操作数据更新
            },
            // 开始拖拽时的函数
            start: (e, ui) => {
              // 拖拽前的父级节点
              dragBeforeParentNode = ui.item[0].parentNode
              // 让placeholder和源高度一致
               ui.placeholder.height(ui.helper[0].scrollHeight).width(258)
               // xxxx  这里可以记录一些拖拽前的元素属性
            },
            // 处理两列滚动条问题
            sort:function(event, ui){
              var scrollContainer = ui.placeholder[0].parentNode
              // 跨列拖拽的情况
              if (dragBeforeParentNode && dragBeforeParentNode.id !== scrollContainer.id) {
                // 设置拽入的列表的滚动位置
                var overflowOffset = $(scrollContainer).offset()
                if((overflowOffset.top + scrollContainer.offsetHeight) - event.pageY < scrollingSensitivity) {
                  scrollContainer.scrollTop = scrollContainer.scrollTop + scrollingSpeed
                } else if(event.pageY - overflowOffset.top < scrollingSensitivity) {
                  scrollContainer.scrollTop = scrollContainer.scrollTop - scrollingSpeed
                }
              }
            }


    sort:function(e, ui){
    array = [];                     
    select_item = ui.item; //当前拖动的元素
    var select_id = select_item.attr("id"); 
    select_sort = select_item.attr("sort"); //当前元素的顺序
    //alert(select_item);
    place_item = $(this).find('tr').filter('.ui-sortable-placeholder').next('tr');//新位置下的下一个元素
    place_sort = place_item.attr('sort');
    
    place_sx = parseInt(place_sort);
    select_sx = parseInt(select_sort);
    
    if(select_sx > place_sx){ //说明是 向上移动
    //array.push(select_id);
    temp = place_sort;
    place_sx = select_sort;//最大
    select_sx = temp;//最小
    flag = false;
    }else{ //向下移动
        place_sort = $(this).find('tr').filter('.ui-sortable-placeholder').prev('tr').attr('sort');
        place_sx = parseInt(place_sort);
        flag = true;
    }
    },
        stop:function(e, ui){
        //ui.item.removeClass("ui-state-highlight"); //释放鼠标时,要用ui.item才是释放的行   
        //发送请求,对sort字段进行修改
        //alert(ui.item.attr("id"));//可以拿到id
        //alert(ui.position.top);//可以拿到id
        var temp = "";
        #{list items:eventTypeList, as:'n'}
        var sort = parseInt(${n.sort});
        if(sort >= select_sx && sort <= place_sx){
    
        if(sort == parseInt(select_sort)){//当前拖拽的元素 向上拖拽,当前元素放在数组第一个,向下,放在数组最后一个
            if(flag){//向下 - 按顺序来
                temp = ${n.id};
            }else{//向上排序
                array.splice(0,0,${n.id});
            }
        }else{
             array.push(${n.id});
        }
        }
    
    
    
     
  • 相关阅读:
    python3 连接HBase
    xgb 绘制
    手机UA识别
    meta常用标签总结
    window.requestAnimationFrame() ,做逐帧动画,你值得拥有
    三年从前端小工到架构-知乎 Live 学习整理
    SEO配置信息操作文档
    函数常见的写法及调用方法整理
    电脑中‘落雪’木马病毒如何解决
    Nuxt学习笔记
  • 原文地址:https://www.cnblogs.com/xumBlog/p/10574384.html
Copyright © 2011-2022 走看看