用Jquery控制元素的上下移動 實現排序功能


在頁面上,控制元素上下移動,進行排序是我們比較常用的功能,今天我用jQuery 寫個 簡單方便,功能齊全的實現方式。

話不多說,直接上代碼,下面是基礎的引入jq和html元素部分:

 <script src="http://code.jquery.com/jquery-1.10.2.js"></script>
<style type="text/css">
  .content{
       float : left;
       height: 245px;
       width : 400px;
  }
   .content p{
         background: #eee;
         border:1px #000 solid;
         height: 30px;
         width: 100%;
   }
   .right{
     float: left;
    margin-left: 10px;
    height: 245px;
    width: 100px;
    padding: 5px;
    margin-top: 84px;
   }
   .right div{
    width: 85px;
    height: 50px;
    margin: 7px;
    text-align: center;
    background: #00BCD4;
    border-radius: 4px;
    cursor: pointer;
    line-height: 3;
   }
</style>
<body>

    <div class="content">
        <p data="false">001</p>
        <p data="false">002</p>
        <p data="false">003</p>
        <p data="false">004</p>
        <p data="false">005</p>
        <p data="false">006</p>
        <p data="false">007</p>
        <p data="false">008</p>
        <p data="false">009</p>
    </div>

    <div  class="right">
        <div onclick="goup()">上移到頂部</div>
        <div onclick="up()">上移</div>
        <div onclick="down()">下移</div>
        <div onclick="godown()">下移到尾部</div>
    </div>

</body>

下面是js 部分:

  var  domp=$('p');
    $(document).ready(function(){
      $("p").on("click",function(){
      var ok=$(this).attr('data');
      for (var i = 0; i < domp.length; i++) {
            if(domp[i]!=this){
            $(domp[i]).attr('data','false');
            $(domp[i]).css("background-color","#eee");
            }
      }
         if(ok=="true"){
              $(this).attr('data',"false");
               $(this).css("background-color","#eee");
          }else{
            $(this).attr('data',"true");
             $(this).css("background-color","pink");
          }
  });
  })
  /**
     *  連續向上
     */
function goup(){

  $.each(domp,function(i,t){
    var fl=$(t).attr('data');
    if(fl=="true"){
        if($(t).prev().size()>0){
            $(t).parent().children("p:first-child").before(t);
        }
    }
  })
}
    /**
     *  向上移動
     */
function up(){
  console.log(domp.children())
  $.each(domp,function(i,t){
    var fl=$(t).attr('data');
    if(fl=="true"){
        if($(t).prev().size()>0){
            $(t).prev().before(t);
        }
    }
  })
}
    /**
     *   向下移動
     **/
function down(){
  $.each(domp,function(i,t){
    var fl=$(t).attr('data');
    if(fl=="true"){
      if($(t).next().size()>0){
          $(t).next().after(t);
        }
      }
  })
}
    /**
     *   連續向下移動
     **/
function godown(){
  $.each(domp,function(i,t){
    var fl=$(t).attr('data');
    if(fl=="true"){
      if($(t).next().size()>0){
           $(t).parent().children("p:last-child").after(t);
        }
      }
  })
}

上述代碼中:

$(document).ready(),$('p').on('click',function(){})是jq比較常用的綁定事件方法,當然還有off()清除事件方法,對這個不了解的同學可以普及一下知識點。
<p data="false">001</p> 和var ok=$(this).attr('data'); 這種寫法,在jq控制元素中很常見,其特點就是給元素綁一個屬性,屬性可以隨便起個名字。在這里,我是用來控制元素是否被選中的,以及用for循環控制職能單選。

$(t).prev()是點擊元素的上一個兄弟節點,jq.before(t)方法是在某個元素jq的上面插入t元素;
$(t).next()獲取的事點擊元素的下個節點,jq.after(t)方法在某個元素jq的下面插入t元素(呃,糾正一下用詞,后面插入,哈哈,結果都一樣)。如圖:


若是有人問,你說好的排序功能呢? 嗯,我的回答是排序只不過是要拿元素的數據值對吧,那么你就遍歷元素$('.content')的孩子p元素,取p元素的值存儲到一個數組就是了。這里就不寫代碼過程了。
文件下載地址:https://files.cnblogs.com/files/mobeisanghai/Jqsort.rar
本期講解就到這里, 本文為作者原創,如有轉載請標明文章出處:
https://www.cnblogs.com/mobeisanghai/p/9318418.html
作者:漠北桑海
 
       


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM